@payloadcms/db-postgres 0.1.0-beta.0

Sign up to get free protection for your applications and to get access to all the features.
Files changed (74) hide show
  1. package/dist/connect.js +82 -0
  2. package/dist/create.js +32 -0
  3. package/dist/createGlobal.js +32 -0
  4. package/dist/createGlobalVersion.js +48 -0
  5. package/dist/createMigration.js +85 -0
  6. package/dist/createVersion.js +54 -0
  7. package/dist/deleteMany.js +44 -0
  8. package/dist/deleteOne.js +47 -0
  9. package/dist/deleteVersions.js +46 -0
  10. package/dist/destroy.js +16 -0
  11. package/dist/find/buildFindManyArgs.js +61 -0
  12. package/dist/find/chainMethods.js +21 -0
  13. package/dist/find/findMany.js +197 -0
  14. package/dist/find/traverseFields.js +118 -0
  15. package/dist/find.js +35 -0
  16. package/dist/findGlobal.js +38 -0
  17. package/dist/findGlobalVersions.js +39 -0
  18. package/dist/findOne.js +49 -0
  19. package/dist/findVersions.js +39 -0
  20. package/dist/index.js +95 -0
  21. package/dist/init.js +74 -0
  22. package/dist/migrate.js +81 -0
  23. package/dist/migrateStatus.js +54 -0
  24. package/dist/mock.js +13 -0
  25. package/dist/queries/buildAndOrConditions.js +39 -0
  26. package/dist/queries/buildQuery.js +80 -0
  27. package/dist/queries/createJSONQuery/convertPathToJSONTraversal.js +24 -0
  28. package/dist/queries/createJSONQuery/formatJSONPathSegment.js +15 -0
  29. package/dist/queries/createJSONQuery/index.js +64 -0
  30. package/dist/queries/getTableColumnFromPath.js +333 -0
  31. package/dist/queries/operatorMap.js +34 -0
  32. package/dist/queries/parseParams.js +146 -0
  33. package/dist/queries/sanitizeQueryValue.js +79 -0
  34. package/dist/queryDrafts.js +56 -0
  35. package/dist/reference.js +76 -0
  36. package/dist/schema/build.js +245 -0
  37. package/dist/schema/createIndex.js +19 -0
  38. package/dist/schema/parentIDColumnMap.js +18 -0
  39. package/dist/schema/traverseFields.js +430 -0
  40. package/dist/schema/validateExistingBlockIsIdentical.js +34 -0
  41. package/dist/transactions/beginTransaction.js +51 -0
  42. package/dist/transactions/commitTransaction.js +24 -0
  43. package/dist/transactions/rollbackTransaction.js +20 -0
  44. package/dist/transform/read/hasManyNumber.js +20 -0
  45. package/dist/transform/read/index.js +42 -0
  46. package/dist/transform/read/relationship.js +74 -0
  47. package/dist/transform/read/traverseFields.js +325 -0
  48. package/dist/transform/write/array.js +55 -0
  49. package/dist/transform/write/blocks.js +56 -0
  50. package/dist/transform/write/index.js +46 -0
  51. package/dist/transform/write/numbers.js +21 -0
  52. package/dist/transform/write/relationships.js +33 -0
  53. package/dist/transform/write/selects.js +29 -0
  54. package/dist/transform/write/traverseFields.js +379 -0
  55. package/dist/transform/write/types.js +6 -0
  56. package/dist/types.js +6 -0
  57. package/dist/update.js +48 -0
  58. package/dist/updateGlobal.js +39 -0
  59. package/dist/updateGlobalVersion.js +50 -0
  60. package/dist/updateVersion.js +50 -0
  61. package/dist/upsertRow/deleteExistingArrayRows.js +20 -0
  62. package/dist/upsertRow/deleteExistingRowsByPath.js +43 -0
  63. package/dist/upsertRow/index.js +243 -0
  64. package/dist/upsertRow/insertArrays.js +64 -0
  65. package/dist/upsertRow/types.js +6 -0
  66. package/dist/utilities/appendPrefixToKeys.js +16 -0
  67. package/dist/utilities/createBlocksMap.js +39 -0
  68. package/dist/utilities/createMigrationTable.js +23 -0
  69. package/dist/utilities/createRelationshipMap.js +29 -0
  70. package/dist/utilities/hasLocalesTable.js +21 -0
  71. package/dist/utilities/isArrayOfRows.js +15 -0
  72. package/dist/utilities/migrationTableExists.js +19 -0
  73. package/dist/webpack.js +30 -0
  74. package/package.json +47 -0
@@ -0,0 +1,197 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", {
3
+ value: true
4
+ });
5
+ Object.defineProperty(exports, "findMany", {
6
+ enumerable: true,
7
+ get: function() {
8
+ return findMany;
9
+ }
10
+ });
11
+ const _drizzleorm = require("drizzle-orm");
12
+ const _buildQuery = /*#__PURE__*/ _interop_require_default(require("../queries/buildQuery"));
13
+ const _read = require("../transform/read");
14
+ const _buildFindManyArgs = require("./buildFindManyArgs");
15
+ const _chainMethods = require("./chainMethods");
16
+ function _interop_require_default(obj) {
17
+ return obj && obj.__esModule ? obj : {
18
+ default: obj
19
+ };
20
+ }
21
+ const findMany = async function find({ adapter, fields, limit: limitArg, locale, page = 1, pagination, req = {}, skip, sort, tableName, where: whereArg }) {
22
+ const db = adapter.sessions[req.transactionID]?.db || adapter.db;
23
+ const table = adapter.tables[tableName];
24
+ let limit = limitArg;
25
+ let totalDocs;
26
+ let totalPages;
27
+ let hasPrevPage;
28
+ let hasNextPage;
29
+ let pagingCounter;
30
+ let selectDistinctResult;
31
+ const { joinAliases, joins, orderBy, selectFields, where } = await (0, _buildQuery.default)({
32
+ adapter,
33
+ fields,
34
+ locale,
35
+ sort,
36
+ tableName,
37
+ where: whereArg
38
+ });
39
+ const orderedIDMap = {};
40
+ const selectDistinctMethods = [];
41
+ if (orderBy?.order && orderBy?.column) {
42
+ selectDistinctMethods.push({
43
+ args: [
44
+ orderBy.order(orderBy.column)
45
+ ],
46
+ method: 'orderBy'
47
+ });
48
+ }
49
+ const findManyArgs = (0, _buildFindManyArgs.buildFindManyArgs)({
50
+ adapter,
51
+ depth: 0,
52
+ fields,
53
+ tableName
54
+ });
55
+ // only fetch IDs when a sort or where query is used that needs to be done on join tables, otherwise these can be done directly on the table in findMany
56
+ if (Object.keys(joins).length > 0 || joinAliases.length > 0) {
57
+ if (where) {
58
+ selectDistinctMethods.push({
59
+ args: [
60
+ where
61
+ ],
62
+ method: 'where'
63
+ });
64
+ }
65
+ joinAliases.forEach(({ condition, table })=>{
66
+ selectDistinctMethods.push({
67
+ args: [
68
+ table,
69
+ condition
70
+ ],
71
+ method: 'leftJoin'
72
+ });
73
+ });
74
+ Object.entries(joins).forEach(([joinTable, condition])=>{
75
+ if (joinTable) {
76
+ selectDistinctMethods.push({
77
+ args: [
78
+ adapter.tables[joinTable],
79
+ condition
80
+ ],
81
+ method: 'leftJoin'
82
+ });
83
+ }
84
+ });
85
+ selectDistinctMethods.push({
86
+ args: [
87
+ skip || (page - 1) * limit
88
+ ],
89
+ method: 'offset'
90
+ });
91
+ selectDistinctMethods.push({
92
+ args: [
93
+ limit === 0 ? undefined : limit
94
+ ],
95
+ method: 'limit'
96
+ });
97
+ selectDistinctResult = await (0, _chainMethods.chainMethods)({
98
+ methods: selectDistinctMethods,
99
+ query: db.selectDistinct(selectFields).from(table)
100
+ });
101
+ if (selectDistinctResult.length === 0) {
102
+ return {
103
+ docs: [],
104
+ hasNextPage: false,
105
+ hasPrevPage: false,
106
+ limit,
107
+ nextPage: null,
108
+ page: 1,
109
+ pagingCounter: 0,
110
+ prevPage: null,
111
+ totalDocs: 0,
112
+ totalPages: 0
113
+ };
114
+ }
115
+ // set the id in an object for sorting later
116
+ selectDistinctResult.forEach(({ id }, i)=>{
117
+ orderedIDMap[id] = i;
118
+ });
119
+ findManyArgs.where = (0, _drizzleorm.inArray)(adapter.tables[tableName].id, Object.keys(orderedIDMap));
120
+ } else {
121
+ findManyArgs.limit = limitArg === 0 ? undefined : limitArg;
122
+ findManyArgs.offset = skip || (page - 1) * limitArg;
123
+ if (where) {
124
+ findManyArgs.where = where;
125
+ }
126
+ findManyArgs.orderBy = orderBy.order(orderBy.column);
127
+ }
128
+ const findPromise = db.query[tableName].findMany(findManyArgs);
129
+ if (pagination !== false || selectDistinctResult?.length > limit) {
130
+ const selectCountMethods = [];
131
+ joinAliases.forEach(({ condition, table })=>{
132
+ selectCountMethods.push({
133
+ args: [
134
+ table,
135
+ condition
136
+ ],
137
+ method: 'leftJoin'
138
+ });
139
+ });
140
+ Object.entries(joins).forEach(([joinTable, condition])=>{
141
+ if (joinTable) {
142
+ selectCountMethods.push({
143
+ args: [
144
+ adapter.tables[joinTable],
145
+ condition
146
+ ],
147
+ method: 'leftJoin'
148
+ });
149
+ }
150
+ });
151
+ const countResult = await (0, _chainMethods.chainMethods)({
152
+ methods: selectCountMethods,
153
+ query: db.select({
154
+ count: (0, _drizzleorm.sql)`count(*)`
155
+ }).from(table).where(where)
156
+ });
157
+ totalDocs = Number(countResult[0].count);
158
+ totalPages = typeof limit === 'number' ? Math.ceil(totalDocs / limit) : 1;
159
+ hasPrevPage = page > 1;
160
+ hasNextPage = totalPages > page;
161
+ pagingCounter = (page - 1) * limit + 1;
162
+ }
163
+ const rawDocs = await findPromise;
164
+ // sort rawDocs from selectQuery
165
+ if (Object.keys(orderedIDMap).length > 0) {
166
+ rawDocs.sort((a, b)=>orderedIDMap[a.id] - orderedIDMap[b.id]);
167
+ }
168
+ if (pagination === false) {
169
+ totalDocs = rawDocs.length;
170
+ limit = totalDocs;
171
+ totalPages = 1;
172
+ pagingCounter = 1;
173
+ hasPrevPage = false;
174
+ hasNextPage = false;
175
+ }
176
+ const docs = rawDocs.map((data)=>{
177
+ return (0, _read.transform)({
178
+ config: adapter.payload.config,
179
+ data,
180
+ fields
181
+ });
182
+ });
183
+ return {
184
+ docs,
185
+ hasNextPage,
186
+ hasPrevPage,
187
+ limit,
188
+ nextPage: hasNextPage ? page + 1 : null,
189
+ page,
190
+ pagingCounter,
191
+ prevPage: hasPrevPage ? page - 1 : null,
192
+ totalDocs,
193
+ totalPages
194
+ };
195
+ };
196
+
197
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../src/find/findMany.ts"],"sourcesContent":["import type { FindArgs } from 'payload/database'\nimport type { Field, PayloadRequest, TypeWithID } from 'payload/types'\n\nimport { inArray, sql } from 'drizzle-orm'\n\nimport type { PostgresAdapter } from '../types'\nimport type { ChainedMethods } from './chainMethods'\n\nimport buildQuery from '../queries/buildQuery'\nimport { transform } from '../transform/read'\nimport { buildFindManyArgs } from './buildFindManyArgs'\nimport { chainMethods } from './chainMethods'\n\ntype Args = Omit<FindArgs, 'collection'> & {\n  adapter: PostgresAdapter\n  fields: Field[]\n  tableName: string\n}\n\nexport const findMany = async function find({\n  adapter,\n  fields,\n  limit: limitArg,\n  locale,\n  page = 1,\n  pagination,\n  req = {} as PayloadRequest,\n  skip,\n  sort,\n  tableName,\n  where: whereArg,\n}: Args) {\n  const db = adapter.sessions[req.transactionID]?.db || adapter.db\n  const table = adapter.tables[tableName]\n\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  let selectDistinctResult\n\n  const { joinAliases, joins, orderBy, selectFields, where } = await buildQuery({\n    adapter,\n    fields,\n    locale,\n    sort,\n    tableName,\n    where: whereArg,\n  })\n\n  const orderedIDMap: Record<number | string, number> = {}\n\n  const selectDistinctMethods: ChainedMethods = []\n\n  if (orderBy?.order && orderBy?.column) {\n    selectDistinctMethods.push({\n      args: [orderBy.order(orderBy.column)],\n      method: 'orderBy',\n    })\n  }\n\n  const findManyArgs = buildFindManyArgs({\n    adapter,\n    depth: 0,\n    fields,\n    tableName,\n  })\n\n  // only fetch IDs when a sort or where query is used that needs to be done on join tables, otherwise these can be done directly on the table in findMany\n  if (Object.keys(joins).length > 0 || joinAliases.length > 0) {\n    if (where) {\n      selectDistinctMethods.push({ args: [where], method: 'where' })\n    }\n\n    joinAliases.forEach(({ condition, table }) => {\n      selectDistinctMethods.push({\n        args: [table, condition],\n        method: 'leftJoin',\n      })\n    })\n\n    Object.entries(joins).forEach(([joinTable, condition]) => {\n      if (joinTable) {\n        selectDistinctMethods.push({\n          args: [adapter.tables[joinTable], condition],\n          method: 'leftJoin',\n        })\n      }\n    })\n\n    selectDistinctMethods.push({ args: [skip || (page - 1) * limit], method: 'offset' })\n    selectDistinctMethods.push({ args: [limit === 0 ? undefined : limit], method: 'limit' })\n\n    selectDistinctResult = await chainMethods({\n      methods: selectDistinctMethods,\n      query: db.selectDistinct(selectFields).from(table),\n    })\n\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    }\n    // set the id in an object for sorting later\n    selectDistinctResult.forEach(({ id }, i) => {\n      orderedIDMap[id as number | string] = i\n    })\n    findManyArgs.where = inArray(adapter.tables[tableName].id, Object.keys(orderedIDMap))\n  } else {\n    findManyArgs.limit = limitArg === 0 ? undefined : limitArg\n    findManyArgs.offset = skip || (page - 1) * limitArg\n    if (where) {\n      findManyArgs.where = where\n    }\n    findManyArgs.orderBy = orderBy.order(orderBy.column)\n  }\n\n  const findPromise = db.query[tableName].findMany(findManyArgs)\n\n  if (pagination !== false || selectDistinctResult?.length > limit) {\n    const selectCountMethods: ChainedMethods = []\n\n    joinAliases.forEach(({ condition, table }) => {\n      selectCountMethods.push({\n        args: [table, condition],\n        method: 'leftJoin',\n      })\n    })\n\n    Object.entries(joins).forEach(([joinTable, condition]) => {\n      if (joinTable) {\n        selectCountMethods.push({\n          args: [adapter.tables[joinTable], condition],\n          method: 'leftJoin',\n        })\n      }\n    })\n\n    const countResult = await chainMethods({\n      methods: selectCountMethods,\n      query: db\n        .select({ count: sql<number>`count(*)` })\n        .from(table)\n        .where(where),\n    })\n    totalDocs = Number(countResult[0].count)\n    totalPages = typeof limit === 'number' ? 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) {\n    totalDocs = rawDocs.length\n    limit = totalDocs\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      config: adapter.payload.config,\n      data,\n      fields,\n    })\n  })\n\n  return {\n    docs,\n    hasNextPage,\n    hasPrevPage,\n    limit,\n    nextPage: hasNextPage ? page + 1 : null,\n    page,\n    pagingCounter,\n    prevPage: hasPrevPage ? page - 1 : null,\n    totalDocs,\n    totalPages,\n  }\n}\n"],"names":["findMany","find","adapter","fields","limit","limitArg","locale","page","pagination","req","skip","sort","tableName","where","whereArg","db","sessions","transactionID","table","tables","totalDocs","totalPages","hasPrevPage","hasNextPage","pagingCounter","selectDistinctResult","joinAliases","joins","orderBy","selectFields","buildQuery","orderedIDMap","selectDistinctMethods","order","column","push","args","method","findManyArgs","buildFindManyArgs","depth","Object","keys","length","forEach","condition","entries","joinTable","undefined","chainMethods","methods","query","selectDistinct","from","docs","nextPage","prevPage","id","i","inArray","offset","findPromise","selectCountMethods","countResult","select","count","sql","Number","Math","ceil","rawDocs","a","b","map","data","transform","config","payload"],"mappings":"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"}
@@ -0,0 +1,118 @@
1
+ /* eslint-disable no-param-reassign */ "use strict";
2
+ Object.defineProperty(exports, "__esModule", {
3
+ value: true
4
+ });
5
+ Object.defineProperty(exports, "traverseFields", {
6
+ enumerable: true,
7
+ get: function() {
8
+ return traverseFields;
9
+ }
10
+ });
11
+ const _types = require("payload/types");
12
+ const _tosnakecase = /*#__PURE__*/ _interop_require_default(require("to-snake-case"));
13
+ function _interop_require_default(obj) {
14
+ return obj && obj.__esModule ? obj : {
15
+ default: obj
16
+ };
17
+ }
18
+ const traverseFields = ({ _locales, adapter, currentArgs, currentTableName, depth, fields, path, topLevelArgs, topLevelTableName })=>{
19
+ fields.forEach((field)=>{
20
+ if ((0, _types.fieldAffectsData)(field)) {
21
+ switch(field.type){
22
+ case 'array':
23
+ {
24
+ const withArray = {
25
+ columns: {
26
+ _parentID: false
27
+ },
28
+ orderBy: ({ _order }, { asc })=>[
29
+ asc(_order)
30
+ ],
31
+ with: {}
32
+ };
33
+ const arrayTableName = `${currentTableName}_${(0, _tosnakecase.default)(field.name)}`;
34
+ if (adapter.tables[`${arrayTableName}_locales`]) withArray.with._locales = _locales;
35
+ currentArgs.with[`${path}${field.name}`] = withArray;
36
+ traverseFields({
37
+ _locales,
38
+ adapter,
39
+ currentArgs: withArray,
40
+ currentTableName: arrayTableName,
41
+ depth,
42
+ fields: field.fields,
43
+ path: '',
44
+ topLevelArgs,
45
+ topLevelTableName
46
+ });
47
+ break;
48
+ }
49
+ case 'select':
50
+ {
51
+ if (field.hasMany) {
52
+ const withSelect = {
53
+ columns: {
54
+ id: false,
55
+ order: false,
56
+ parent: false
57
+ },
58
+ orderBy: ({ order }, { asc })=>[
59
+ asc(order)
60
+ ]
61
+ };
62
+ currentArgs.with[`${path}${field.name}`] = withSelect;
63
+ }
64
+ break;
65
+ }
66
+ case 'blocks':
67
+ field.blocks.forEach((block)=>{
68
+ const blockKey = `_blocks_${block.slug}`;
69
+ if (!topLevelArgs[blockKey]) {
70
+ const withBlock = {
71
+ columns: {
72
+ _parentID: false
73
+ },
74
+ orderBy: ({ _order }, { asc })=>[
75
+ asc(_order)
76
+ ],
77
+ with: {}
78
+ };
79
+ if (adapter.tables[`${topLevelTableName}_${(0, _tosnakecase.default)(block.slug)}_locales`]) withBlock.with._locales = _locales;
80
+ topLevelArgs.with[blockKey] = withBlock;
81
+ traverseFields({
82
+ _locales,
83
+ adapter,
84
+ currentArgs: withBlock,
85
+ currentTableName,
86
+ depth,
87
+ fields: block.fields,
88
+ path,
89
+ topLevelArgs,
90
+ topLevelTableName
91
+ });
92
+ }
93
+ });
94
+ break;
95
+ case 'group':
96
+ traverseFields({
97
+ _locales,
98
+ adapter,
99
+ currentArgs,
100
+ currentTableName,
101
+ depth,
102
+ fields: field.fields,
103
+ path: `${path}${field.name}_`,
104
+ topLevelArgs,
105
+ topLevelTableName
106
+ });
107
+ break;
108
+ default:
109
+ {
110
+ break;
111
+ }
112
+ }
113
+ }
114
+ });
115
+ return topLevelArgs;
116
+ };
117
+
118
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../src/find/traverseFields.ts"],"sourcesContent":["/* eslint-disable no-param-reassign */\nimport type { Field } from 'payload/types'\n\nimport { fieldAffectsData } from 'payload/types'\nimport toSnakeCase from 'to-snake-case'\n\nimport type { PostgresAdapter } from '../types'\nimport type { Result } from './buildFindManyArgs'\n\ntype TraverseFieldArgs = {\n  _locales: Record<string, unknown>\n  adapter: PostgresAdapter\n  currentArgs: Record<string, unknown>\n  currentTableName: string\n  depth?: number\n  fields: Field[]\n  path: string\n  topLevelArgs: Record<string, unknown>\n  topLevelTableName: string\n}\n\nexport const traverseFields = ({\n  _locales,\n  adapter,\n  currentArgs,\n  currentTableName,\n  depth,\n  fields,\n  path,\n  topLevelArgs,\n  topLevelTableName,\n}: TraverseFieldArgs) => {\n  fields.forEach((field) => {\n    if (fieldAffectsData(field)) {\n      switch (field.type) {\n        case 'array': {\n          const withArray: Result = {\n            columns: {\n              _parentID: false,\n            },\n            orderBy: ({ _order }, { asc }) => [asc(_order)],\n            with: {},\n          }\n\n          const arrayTableName = `${currentTableName}_${toSnakeCase(field.name)}`\n\n          if (adapter.tables[`${arrayTableName}_locales`]) withArray.with._locales = _locales\n          currentArgs.with[`${path}${field.name}`] = withArray\n\n          traverseFields({\n            _locales,\n            adapter,\n            currentArgs: withArray,\n            currentTableName: arrayTableName,\n            depth,\n            fields: field.fields,\n            path: '',\n            topLevelArgs,\n            topLevelTableName,\n          })\n\n          break\n        }\n\n        case 'select': {\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          }\n\n          break\n        }\n\n        case 'blocks':\n          field.blocks.forEach((block) => {\n            const blockKey = `_blocks_${block.slug}`\n\n            if (!topLevelArgs[blockKey]) {\n              const withBlock: Result = {\n                columns: {\n                  _parentID: false,\n                },\n                orderBy: ({ _order }, { asc }) => [asc(_order)],\n                with: {},\n              }\n\n              if (adapter.tables[`${topLevelTableName}_${toSnakeCase(block.slug)}_locales`])\n                withBlock.with._locales = _locales\n              topLevelArgs.with[blockKey] = withBlock\n\n              traverseFields({\n                _locales,\n                adapter,\n                currentArgs: withBlock,\n                currentTableName,\n                depth,\n                fields: block.fields,\n                path,\n                topLevelArgs,\n                topLevelTableName,\n              })\n            }\n          })\n\n          break\n\n        case 'group':\n          traverseFields({\n            _locales,\n            adapter,\n            currentArgs,\n            currentTableName,\n            depth,\n            fields: field.fields,\n            path: `${path}${field.name}_`,\n            topLevelArgs,\n            topLevelTableName,\n          })\n\n          break\n\n        default: {\n          break\n        }\n      }\n    }\n  })\n\n  return topLevelArgs\n}\n"],"names":["traverseFields","_locales","adapter","currentArgs","currentTableName","depth","fields","path","topLevelArgs","topLevelTableName","forEach","field","fieldAffectsData","type","withArray","columns","_parentID","orderBy","_order","asc","with","arrayTableName","toSnakeCase","name","tables","hasMany","withSelect","id","order","parent","blocks","block","blockKey","slug","withBlock"],"mappings":"AAAA,oCAAoC;;;;+BAqBvBA;;;eAAAA;;;uBAlBoB;oEACT;;;;;;AAiBjB,MAAMA,iBAAiB,CAAC,EAC7BC,QAAQ,EACRC,OAAO,EACPC,WAAW,EACXC,gBAAgB,EAChBC,KAAK,EACLC,MAAM,EACNC,IAAI,EACJC,YAAY,EACZC,iBAAiB,EACC;IAClBH,OAAOI,OAAO,CAAC,CAACC;QACd,IAAIC,IAAAA,uBAAgB,EAACD,QAAQ;YAC3B,OAAQA,MAAME,IAAI;gBAChB,KAAK;oBAAS;wBACZ,MAAMC,YAAoB;4BACxBC,SAAS;gCACPC,WAAW;4BACb;4BACAC,SAAS,CAAC,EAAEC,MAAM,EAAE,EAAE,EAAEC,GAAG,EAAE,GAAK;oCAACA,IAAID;iCAAQ;4BAC/CE,MAAM,CAAC;wBACT;wBAEA,MAAMC,iBAAiB,CAAC,EAAEjB,iBAAiB,CAAC,EAAEkB,IAAAA,oBAAW,EAACX,MAAMY,IAAI,EAAE,CAAC;wBAEvE,IAAIrB,QAAQsB,MAAM,CAAC,CAAC,EAAEH,eAAe,QAAQ,CAAC,CAAC,EAAEP,UAAUM,IAAI,CAACnB,QAAQ,GAAGA;wBAC3EE,YAAYiB,IAAI,CAAC,CAAC,EAAEb,KAAK,EAAEI,MAAMY,IAAI,CAAC,CAAC,CAAC,GAAGT;wBAE3Cd,eAAe;4BACbC;4BACAC;4BACAC,aAAaW;4BACbV,kBAAkBiB;4BAClBhB;4BACAC,QAAQK,MAAML,MAAM;4BACpBC,MAAM;4BACNC;4BACAC;wBACF;wBAEA;oBACF;gBAEA,KAAK;oBAAU;wBACb,IAAIE,MAAMc,OAAO,EAAE;4BACjB,MAAMC,aAAqB;gCACzBX,SAAS;oCACPY,IAAI;oCACJC,OAAO;oCACPC,QAAQ;gCACV;gCACAZ,SAAS,CAAC,EAAEW,KAAK,EAAE,EAAE,EAAET,GAAG,EAAE,GAAK;wCAACA,IAAIS;qCAAO;4BAC/C;4BAEAzB,YAAYiB,IAAI,CAAC,CAAC,EAAEb,KAAK,EAAEI,MAAMY,IAAI,CAAC,CAAC,CAAC,GAAGG;wBAC7C;wBAEA;oBACF;gBAEA,KAAK;oBACHf,MAAMmB,MAAM,CAACpB,OAAO,CAAC,CAACqB;wBACpB,MAAMC,WAAW,CAAC,QAAQ,EAAED,MAAME,IAAI,CAAC,CAAC;wBAExC,IAAI,CAACzB,YAAY,CAACwB,SAAS,EAAE;4BAC3B,MAAME,YAAoB;gCACxBnB,SAAS;oCACPC,WAAW;gCACb;gCACAC,SAAS,CAAC,EAAEC,MAAM,EAAE,EAAE,EAAEC,GAAG,EAAE,GAAK;wCAACA,IAAID;qCAAQ;gCAC/CE,MAAM,CAAC;4BACT;4BAEA,IAAIlB,QAAQsB,MAAM,CAAC,CAAC,EAAEf,kBAAkB,CAAC,EAAEa,IAAAA,oBAAW,EAACS,MAAME,IAAI,EAAE,QAAQ,CAAC,CAAC,EAC3EC,UAAUd,IAAI,CAACnB,QAAQ,GAAGA;4BAC5BO,aAAaY,IAAI,CAACY,SAAS,GAAGE;4BAE9BlC,eAAe;gCACbC;gCACAC;gCACAC,aAAa+B;gCACb9B;gCACAC;gCACAC,QAAQyB,MAAMzB,MAAM;gCACpBC;gCACAC;gCACAC;4BACF;wBACF;oBACF;oBAEA;gBAEF,KAAK;oBACHT,eAAe;wBACbC;wBACAC;wBACAC;wBACAC;wBACAC;wBACAC,QAAQK,MAAML,MAAM;wBACpBC,MAAM,CAAC,EAAEA,KAAK,EAAEI,MAAMY,IAAI,CAAC,CAAC,CAAC;wBAC7Bf;wBACAC;oBACF;oBAEA;gBAEF;oBAAS;wBACP;oBACF;YACF;QACF;IACF;IAEA,OAAOD;AACT"}
package/dist/find.js ADDED
@@ -0,0 +1,35 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", {
3
+ value: true
4
+ });
5
+ Object.defineProperty(exports, "find", {
6
+ enumerable: true,
7
+ get: function() {
8
+ return find;
9
+ }
10
+ });
11
+ const _tosnakecase = /*#__PURE__*/ _interop_require_default(require("to-snake-case"));
12
+ const _findMany = require("./find/findMany");
13
+ function _interop_require_default(obj) {
14
+ return obj && obj.__esModule ? obj : {
15
+ default: obj
16
+ };
17
+ }
18
+ const find = async function find({ collection, limit: limitArg, locale, page = 1, pagination, req = {}, sort: sortArg, where: whereArg }) {
19
+ const collectionConfig = this.payload.collections[collection].config;
20
+ const sort = typeof sortArg === 'string' ? sortArg : collectionConfig.defaultSort;
21
+ return (0, _findMany.findMany)({
22
+ adapter: this,
23
+ fields: collectionConfig.fields,
24
+ limit: limitArg,
25
+ locale,
26
+ page,
27
+ pagination,
28
+ req,
29
+ sort,
30
+ tableName: (0, _tosnakecase.default)(collection),
31
+ where: whereArg
32
+ });
33
+ };
34
+
35
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uL3NyYy9maW5kLnRzIl0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB0eXBlIHsgRmluZCB9IGZyb20gJ3BheWxvYWQvZGF0YWJhc2UnXG5pbXBvcnQgdHlwZSB7IFBheWxvYWRSZXF1ZXN0LCBTYW5pdGl6ZWRDb2xsZWN0aW9uQ29uZmlnIH0gZnJvbSAncGF5bG9hZC90eXBlcydcblxuaW1wb3J0IHRvU25ha2VDYXNlIGZyb20gJ3RvLXNuYWtlLWNhc2UnXG5cbmltcG9ydCB0eXBlIHsgUG9zdGdyZXNBZGFwdGVyIH0gZnJvbSAnLi90eXBlcydcblxuaW1wb3J0IHsgZmluZE1hbnkgfSBmcm9tICcuL2ZpbmQvZmluZE1hbnknXG5cbmV4cG9ydCBjb25zdCBmaW5kOiBGaW5kID0gYXN5bmMgZnVuY3Rpb24gZmluZChcbiAgdGhpczogUG9zdGdyZXNBZGFwdGVyLFxuICB7XG4gICAgY29sbGVjdGlvbixcbiAgICBsaW1pdDogbGltaXRBcmcsXG4gICAgbG9jYWxlLFxuICAgIHBhZ2UgPSAxLFxuICAgIHBhZ2luYXRpb24sXG4gICAgcmVxID0ge30gYXMgUGF5bG9hZFJlcXVlc3QsXG4gICAgc29ydDogc29ydEFyZyxcbiAgICB3aGVyZTogd2hlcmVBcmcsXG4gIH0sXG4pIHtcbiAgY29uc3QgY29sbGVjdGlvbkNvbmZpZzogU2FuaXRpemVkQ29sbGVjdGlvbkNvbmZpZyA9IHRoaXMucGF5bG9hZC5jb2xsZWN0aW9uc1tjb2xsZWN0aW9uXS5jb25maWdcbiAgY29uc3Qgc29ydCA9IHR5cGVvZiBzb3J0QXJnID09PSAnc3RyaW5nJyA/IHNvcnRBcmcgOiBjb2xsZWN0aW9uQ29uZmlnLmRlZmF1bHRTb3J0XG5cbiAgcmV0dXJuIGZpbmRNYW55KHtcbiAgICBhZGFwdGVyOiB0aGlzLFxuICAgIGZpZWxkczogY29sbGVjdGlvbkNvbmZpZy5maWVsZHMsXG4gICAgbGltaXQ6IGxpbWl0QXJnLFxuICAgIGxvY2FsZSxcbiAgICBwYWdlLFxuICAgIHBhZ2luYXRpb24sXG4gICAgcmVxLFxuICAgIHNvcnQsXG4gICAgdGFibGVOYW1lOiB0b1NuYWtlQ2FzZShjb2xsZWN0aW9uKSxcbiAgICB3aGVyZTogd2hlcmVBcmcsXG4gIH0pXG59XG4iXSwibmFtZXMiOlsiZmluZCIsImNvbGxlY3Rpb24iLCJsaW1pdCIsImxpbWl0QXJnIiwibG9jYWxlIiwicGFnZSIsInBhZ2luYXRpb24iLCJyZXEiLCJzb3J0Iiwic29ydEFyZyIsIndoZXJlIiwid2hlcmVBcmciLCJjb2xsZWN0aW9uQ29uZmlnIiwicGF5bG9hZCIsImNvbGxlY3Rpb25zIiwiY29uZmlnIiwiZGVmYXVsdFNvcnQiLCJmaW5kTWFueSIsImFkYXB0ZXIiLCJmaWVsZHMiLCJ0YWJsZU5hbWUiLCJ0b1NuYWtlQ2FzZSJdLCJtYXBwaW5ncyI6Ijs7OzsrQkFTYUE7OztlQUFBQTs7O29FQU5XOzBCQUlDOzs7Ozs7QUFFbEIsTUFBTUEsT0FBYSxlQUFlQSxLQUV2QyxFQUNFQyxVQUFVLEVBQ1ZDLE9BQU9DLFFBQVEsRUFDZkMsTUFBTSxFQUNOQyxPQUFPLENBQUMsRUFDUkMsVUFBVSxFQUNWQyxNQUFNLENBQUMsQ0FBbUIsRUFDMUJDLE1BQU1DLE9BQU8sRUFDYkMsT0FBT0MsUUFBUSxFQUNoQjtJQUVELE1BQU1DLG1CQUE4QyxJQUFJLENBQUNDLE9BQU8sQ0FBQ0MsV0FBVyxDQUFDYixXQUFXLENBQUNjLE1BQU07SUFDL0YsTUFBTVAsT0FBTyxPQUFPQyxZQUFZLFdBQVdBLFVBQVVHLGlCQUFpQkksV0FBVztJQUVqRixPQUFPQyxJQUFBQSxrQkFBUSxFQUFDO1FBQ2RDLFNBQVMsSUFBSTtRQUNiQyxRQUFRUCxpQkFBaUJPLE1BQU07UUFDL0JqQixPQUFPQztRQUNQQztRQUNBQztRQUNBQztRQUNBQztRQUNBQztRQUNBWSxXQUFXQyxJQUFBQSxvQkFBVyxFQUFDcEI7UUFDdkJTLE9BQU9DO0lBQ1Q7QUFDRiJ9
@@ -0,0 +1,38 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", {
3
+ value: true
4
+ });
5
+ Object.defineProperty(exports, "findGlobal", {
6
+ enumerable: true,
7
+ get: function() {
8
+ return findGlobal;
9
+ }
10
+ });
11
+ const _tosnakecase = /*#__PURE__*/ _interop_require_default(require("to-snake-case"));
12
+ const _findMany = require("./find/findMany");
13
+ function _interop_require_default(obj) {
14
+ return obj && obj.__esModule ? obj : {
15
+ default: obj
16
+ };
17
+ }
18
+ const findGlobal = async function findGlobal({ locale, req, slug, where }) {
19
+ const globalConfig = this.payload.globals.config.find((config)=>config.slug === slug);
20
+ const tableName = (0, _tosnakecase.default)(slug);
21
+ const { docs: [doc] } = await (0, _findMany.findMany)({
22
+ adapter: this,
23
+ fields: globalConfig.fields,
24
+ limit: 1,
25
+ locale,
26
+ pagination: false,
27
+ req,
28
+ tableName,
29
+ where
30
+ });
31
+ if (doc) {
32
+ doc.globalType = slug;
33
+ return doc;
34
+ }
35
+ return {};
36
+ };
37
+
38
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uL3NyYy9maW5kR2xvYmFsLnRzIl0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB0eXBlIHsgRmluZEdsb2JhbCB9IGZyb20gJ3BheWxvYWQvZGF0YWJhc2UnXG5cbmltcG9ydCB0b1NuYWtlQ2FzZSBmcm9tICd0by1zbmFrZS1jYXNlJ1xuXG5pbXBvcnQgdHlwZSB7IFBvc3RncmVzQWRhcHRlciB9IGZyb20gJy4vdHlwZXMnXG5cbmltcG9ydCB7IGZpbmRNYW55IH0gZnJvbSAnLi9maW5kL2ZpbmRNYW55J1xuXG5leHBvcnQgY29uc3QgZmluZEdsb2JhbDogRmluZEdsb2JhbCA9IGFzeW5jIGZ1bmN0aW9uIGZpbmRHbG9iYWwoXG4gIHRoaXM6IFBvc3RncmVzQWRhcHRlcixcbiAgeyBsb2NhbGUsIHJlcSwgc2x1Zywgd2hlcmUgfSxcbikge1xuICBjb25zdCBnbG9iYWxDb25maWcgPSB0aGlzLnBheWxvYWQuZ2xvYmFscy5jb25maWcuZmluZCgoY29uZmlnKSA9PiBjb25maWcuc2x1ZyA9PT0gc2x1ZylcbiAgY29uc3QgdGFibGVOYW1lID0gdG9TbmFrZUNhc2Uoc2x1ZylcblxuICBjb25zdCB7XG4gICAgZG9jczogW2RvY10sXG4gIH0gPSBhd2FpdCBmaW5kTWFueSh7XG4gICAgYWRhcHRlcjogdGhpcyxcbiAgICBmaWVsZHM6IGdsb2JhbENvbmZpZy5maWVsZHMsXG4gICAgbGltaXQ6IDEsXG4gICAgbG9jYWxlLFxuICAgIHBhZ2luYXRpb246IGZhbHNlLFxuICAgIHJlcSxcbiAgICB0YWJsZU5hbWUsXG4gICAgd2hlcmUsXG4gIH0pXG5cbiAgaWYgKGRvYykge1xuICAgIGRvYy5nbG9iYWxUeXBlID0gc2x1Z1xuICAgIHJldHVybiBkb2NcbiAgfVxuXG4gIHJldHVybiB7fVxufVxuIl0sIm5hbWVzIjpbImZpbmRHbG9iYWwiLCJsb2NhbGUiLCJyZXEiLCJzbHVnIiwid2hlcmUiLCJnbG9iYWxDb25maWciLCJwYXlsb2FkIiwiZ2xvYmFscyIsImNvbmZpZyIsImZpbmQiLCJ0YWJsZU5hbWUiLCJ0b1NuYWtlQ2FzZSIsImRvY3MiLCJkb2MiLCJmaW5kTWFueSIsImFkYXB0ZXIiLCJmaWVsZHMiLCJsaW1pdCIsInBhZ2luYXRpb24iLCJnbG9iYWxUeXBlIl0sIm1hcHBpbmdzIjoiOzs7OytCQVFhQTs7O2VBQUFBOzs7b0VBTlc7MEJBSUM7Ozs7OztBQUVsQixNQUFNQSxhQUF5QixlQUFlQSxXQUVuRCxFQUFFQyxNQUFNLEVBQUVDLEdBQUcsRUFBRUMsSUFBSSxFQUFFQyxLQUFLLEVBQUU7SUFFNUIsTUFBTUMsZUFBZSxJQUFJLENBQUNDLE9BQU8sQ0FBQ0MsT0FBTyxDQUFDQyxNQUFNLENBQUNDLElBQUksQ0FBQyxDQUFDRCxTQUFXQSxPQUFPTCxJQUFJLEtBQUtBO0lBQ2xGLE1BQU1PLFlBQVlDLElBQUFBLG9CQUFXLEVBQUNSO0lBRTlCLE1BQU0sRUFDSlMsTUFBTSxDQUFDQyxJQUFJLEVBQ1osR0FBRyxNQUFNQyxJQUFBQSxrQkFBUSxFQUFDO1FBQ2pCQyxTQUFTLElBQUk7UUFDYkMsUUFBUVgsYUFBYVcsTUFBTTtRQUMzQkMsT0FBTztRQUNQaEI7UUFDQWlCLFlBQVk7UUFDWmhCO1FBQ0FRO1FBQ0FOO0lBQ0Y7SUFFQSxJQUFJUyxLQUFLO1FBQ1BBLElBQUlNLFVBQVUsR0FBR2hCO1FBQ2pCLE9BQU9VO0lBQ1Q7SUFFQSxPQUFPLENBQUM7QUFDViJ9
@@ -0,0 +1,39 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", {
3
+ value: true
4
+ });
5
+ Object.defineProperty(exports, "findGlobalVersions", {
6
+ enumerable: true,
7
+ get: function() {
8
+ return findGlobalVersions;
9
+ }
10
+ });
11
+ const _versions = require("payload/versions");
12
+ const _tosnakecase = /*#__PURE__*/ _interop_require_default(require("to-snake-case"));
13
+ const _findMany = require("./find/findMany");
14
+ function _interop_require_default(obj) {
15
+ return obj && obj.__esModule ? obj : {
16
+ default: obj
17
+ };
18
+ }
19
+ const findGlobalVersions = async function findGlobalVersions({ global, limit, locale, page, pagination, req = {}, skip, sort: sortArg, where }) {
20
+ const globalConfig = this.payload.globals.config.find(({ slug })=>slug === global);
21
+ const sort = typeof sortArg === 'string' ? sortArg : '-createdAt';
22
+ const tableName = `_${(0, _tosnakecase.default)(global)}_v`;
23
+ const fields = (0, _versions.buildVersionGlobalFields)(globalConfig);
24
+ return (0, _findMany.findMany)({
25
+ adapter: this,
26
+ fields,
27
+ limit,
28
+ locale,
29
+ page,
30
+ pagination,
31
+ req,
32
+ skip,
33
+ sort,
34
+ tableName,
35
+ where
36
+ });
37
+ };
38
+
39
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uL3NyYy9maW5kR2xvYmFsVmVyc2lvbnMudHMiXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHR5cGUgeyBGaW5kR2xvYmFsVmVyc2lvbnMgfSBmcm9tICdwYXlsb2FkL2RhdGFiYXNlJ1xuaW1wb3J0IHR5cGUgeyBQYXlsb2FkUmVxdWVzdCwgU2FuaXRpemVkR2xvYmFsQ29uZmlnIH0gZnJvbSAncGF5bG9hZC90eXBlcydcblxuaW1wb3J0IHsgYnVpbGRWZXJzaW9uR2xvYmFsRmllbGRzIH0gZnJvbSAncGF5bG9hZC92ZXJzaW9ucydcbmltcG9ydCB0b1NuYWtlQ2FzZSBmcm9tICd0by1zbmFrZS1jYXNlJ1xuXG5pbXBvcnQgdHlwZSB7IFBvc3RncmVzQWRhcHRlciB9IGZyb20gJy4vdHlwZXMnXG5cbmltcG9ydCB7IGZpbmRNYW55IH0gZnJvbSAnLi9maW5kL2ZpbmRNYW55J1xuXG5leHBvcnQgY29uc3QgZmluZEdsb2JhbFZlcnNpb25zOiBGaW5kR2xvYmFsVmVyc2lvbnMgPSBhc3luYyBmdW5jdGlvbiBmaW5kR2xvYmFsVmVyc2lvbnMoXG4gIHRoaXM6IFBvc3RncmVzQWRhcHRlcixcbiAge1xuICAgIGdsb2JhbCxcbiAgICBsaW1pdCxcbiAgICBsb2NhbGUsXG4gICAgcGFnZSxcbiAgICBwYWdpbmF0aW9uLFxuICAgIHJlcSA9IHt9IGFzIFBheWxvYWRSZXF1ZXN0LFxuICAgIHNraXAsXG4gICAgc29ydDogc29ydEFyZyxcbiAgICB3aGVyZSxcbiAgfSxcbikge1xuICBjb25zdCBnbG9iYWxDb25maWc6IFNhbml0aXplZEdsb2JhbENvbmZpZyA9IHRoaXMucGF5bG9hZC5nbG9iYWxzLmNvbmZpZy5maW5kKFxuICAgICh7IHNsdWcgfSkgPT4gc2x1ZyA9PT0gZ2xvYmFsLFxuICApXG4gIGNvbnN0IHNvcnQgPSB0eXBlb2Ygc29ydEFyZyA9PT0gJ3N0cmluZycgPyBzb3J0QXJnIDogJy1jcmVhdGVkQXQnXG5cbiAgY29uc3QgdGFibGVOYW1lID0gYF8ke3RvU25ha2VDYXNlKGdsb2JhbCl9X3ZgXG4gIGNvbnN0IGZpZWxkcyA9IGJ1aWxkVmVyc2lvbkdsb2JhbEZpZWxkcyhnbG9iYWxDb25maWcpXG5cbiAgcmV0dXJuIGZpbmRNYW55KHtcbiAgICBhZGFwdGVyOiB0aGlzLFxuICAgIGZpZWxkcyxcbiAgICBsaW1pdCxcbiAgICBsb2NhbGUsXG4gICAgcGFnZSxcbiAgICBwYWdpbmF0aW9uLFxuICAgIHJlcSxcbiAgICBza2lwLFxuICAgIHNvcnQsXG4gICAgdGFibGVOYW1lLFxuICAgIHdoZXJlLFxuICB9KVxufVxuIl0sIm5hbWVzIjpbImZpbmRHbG9iYWxWZXJzaW9ucyIsImdsb2JhbCIsImxpbWl0IiwibG9jYWxlIiwicGFnZSIsInBhZ2luYXRpb24iLCJyZXEiLCJza2lwIiwic29ydCIsInNvcnRBcmciLCJ3aGVyZSIsImdsb2JhbENvbmZpZyIsInBheWxvYWQiLCJnbG9iYWxzIiwiY29uZmlnIiwiZmluZCIsInNsdWciLCJ0YWJsZU5hbWUiLCJ0b1NuYWtlQ2FzZSIsImZpZWxkcyIsImJ1aWxkVmVyc2lvbkdsb2JhbEZpZWxkcyIsImZpbmRNYW55IiwiYWRhcHRlciJdLCJtYXBwaW5ncyI6Ijs7OzsrQkFVYUE7OztlQUFBQTs7OzBCQVA0QjtvRUFDakI7MEJBSUM7Ozs7OztBQUVsQixNQUFNQSxxQkFBeUMsZUFBZUEsbUJBRW5FLEVBQ0VDLE1BQU0sRUFDTkMsS0FBSyxFQUNMQyxNQUFNLEVBQ05DLElBQUksRUFDSkMsVUFBVSxFQUNWQyxNQUFNLENBQUMsQ0FBbUIsRUFDMUJDLElBQUksRUFDSkMsTUFBTUMsT0FBTyxFQUNiQyxLQUFLLEVBQ047SUFFRCxNQUFNQyxlQUFzQyxJQUFJLENBQUNDLE9BQU8sQ0FBQ0MsT0FBTyxDQUFDQyxNQUFNLENBQUNDLElBQUksQ0FDMUUsQ0FBQyxFQUFFQyxJQUFJLEVBQUUsR0FBS0EsU0FBU2Y7SUFFekIsTUFBTU8sT0FBTyxPQUFPQyxZQUFZLFdBQVdBLFVBQVU7SUFFckQsTUFBTVEsWUFBWSxDQUFDLENBQUMsRUFBRUMsSUFBQUEsb0JBQVcsRUFBQ2pCLFFBQVEsRUFBRSxDQUFDO0lBQzdDLE1BQU1rQixTQUFTQyxJQUFBQSxrQ0FBd0IsRUFBQ1Q7SUFFeEMsT0FBT1UsSUFBQUEsa0JBQVEsRUFBQztRQUNkQyxTQUFTLElBQUk7UUFDYkg7UUFDQWpCO1FBQ0FDO1FBQ0FDO1FBQ0FDO1FBQ0FDO1FBQ0FDO1FBQ0FDO1FBQ0FTO1FBQ0FQO0lBQ0Y7QUFDRiJ9
@@ -0,0 +1,49 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", {
3
+ value: true
4
+ });
5
+ Object.defineProperty(exports, "findOne", {
6
+ enumerable: true,
7
+ get: function() {
8
+ return findOne;
9
+ }
10
+ });
11
+ const _tosnakecase = /*#__PURE__*/ _interop_require_default(require("to-snake-case"));
12
+ const _buildFindManyArgs = require("./find/buildFindManyArgs");
13
+ const _buildQuery = /*#__PURE__*/ _interop_require_default(require("./queries/buildQuery"));
14
+ const _read = require("./transform/read");
15
+ function _interop_require_default(obj) {
16
+ return obj && obj.__esModule ? obj : {
17
+ default: obj
18
+ };
19
+ }
20
+ async function findOne({ collection, locale, req = {}, where: incomingWhere }) {
21
+ const db = this.sessions[req.transactionID]?.db || this.db;
22
+ const collectionConfig = this.payload.collections[collection].config;
23
+ const tableName = (0, _tosnakecase.default)(collection);
24
+ const { where } = await (0, _buildQuery.default)({
25
+ adapter: this,
26
+ fields: collectionConfig.fields,
27
+ locale,
28
+ tableName,
29
+ where: incomingWhere
30
+ });
31
+ const findManyArgs = (0, _buildFindManyArgs.buildFindManyArgs)({
32
+ adapter: this,
33
+ depth: 0,
34
+ fields: collectionConfig.fields,
35
+ tableName
36
+ });
37
+ findManyArgs.where = where;
38
+ const doc = await db.query[tableName].findFirst(findManyArgs);
39
+ if (!doc) {
40
+ return null;
41
+ }
42
+ return (0, _read.transform)({
43
+ config: this.payload.config,
44
+ data: doc,
45
+ fields: collectionConfig.fields
46
+ });
47
+ }
48
+
49
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uL3NyYy9maW5kT25lLnRzIl0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB0eXBlIHsgRmluZE9uZUFyZ3MgfSBmcm9tICdwYXlsb2FkL2RhdGFiYXNlJ1xuaW1wb3J0IHR5cGUgeyBQYXlsb2FkUmVxdWVzdCwgU2FuaXRpemVkQ29sbGVjdGlvbkNvbmZpZywgVHlwZVdpdGhJRCB9IGZyb20gJ3BheWxvYWQvdHlwZXMnXG5cbmltcG9ydCB0b1NuYWtlQ2FzZSBmcm9tICd0by1zbmFrZS1jYXNlJ1xuXG5pbXBvcnQgdHlwZSB7IFBvc3RncmVzQWRhcHRlciB9IGZyb20gJy4vdHlwZXMnXG5cbmltcG9ydCB7IGJ1aWxkRmluZE1hbnlBcmdzIH0gZnJvbSAnLi9maW5kL2J1aWxkRmluZE1hbnlBcmdzJ1xuaW1wb3J0IGJ1aWxkUXVlcnkgZnJvbSAnLi9xdWVyaWVzL2J1aWxkUXVlcnknXG5pbXBvcnQgeyB0cmFuc2Zvcm0gfSBmcm9tICcuL3RyYW5zZm9ybS9yZWFkJ1xuXG5leHBvcnQgYXN5bmMgZnVuY3Rpb24gZmluZE9uZTxUIGV4dGVuZHMgVHlwZVdpdGhJRD4oXG4gIHRoaXM6IFBvc3RncmVzQWRhcHRlcixcbiAgeyBjb2xsZWN0aW9uLCBsb2NhbGUsIHJlcSA9IHt9IGFzIFBheWxvYWRSZXF1ZXN0LCB3aGVyZTogaW5jb21pbmdXaGVyZSB9OiBGaW5kT25lQXJncyxcbik6IFByb21pc2U8VD4ge1xuICBjb25zdCBkYiA9IHRoaXMuc2Vzc2lvbnNbcmVxLnRyYW5zYWN0aW9uSURdPy5kYiB8fCB0aGlzLmRiXG4gIGNvbnN0IGNvbGxlY3Rpb25Db25maWc6IFNhbml0aXplZENvbGxlY3Rpb25Db25maWcgPSB0aGlzLnBheWxvYWQuY29sbGVjdGlvbnNbY29sbGVjdGlvbl0uY29uZmlnXG4gIGNvbnN0IHRhYmxlTmFtZSA9IHRvU25ha2VDYXNlKGNvbGxlY3Rpb24pXG5cbiAgY29uc3QgeyB3aGVyZSB9ID0gYXdhaXQgYnVpbGRRdWVyeSh7XG4gICAgYWRhcHRlcjogdGhpcyxcbiAgICBmaWVsZHM6IGNvbGxlY3Rpb25Db25maWcuZmllbGRzLFxuICAgIGxvY2FsZSxcbiAgICB0YWJsZU5hbWUsXG4gICAgd2hlcmU6IGluY29taW5nV2hlcmUsXG4gIH0pXG5cbiAgY29uc3QgZmluZE1hbnlBcmdzID0gYnVpbGRGaW5kTWFueUFyZ3Moe1xuICAgIGFkYXB0ZXI6IHRoaXMsXG4gICAgZGVwdGg6IDAsXG4gICAgZmllbGRzOiBjb2xsZWN0aW9uQ29uZmlnLmZpZWxkcyxcbiAgICB0YWJsZU5hbWUsXG4gIH0pXG5cbiAgZmluZE1hbnlBcmdzLndoZXJlID0gd2hlcmVcblxuICBjb25zdCBkb2MgPSBhd2FpdCBkYi5xdWVyeVt0YWJsZU5hbWVdLmZpbmRGaXJzdChmaW5kTWFueUFyZ3MpXG5cbiAgaWYgKCFkb2MpIHtcbiAgICByZXR1cm4gbnVsbFxuICB9XG5cbiAgcmV0dXJuIHRyYW5zZm9ybTxUPih7XG4gICAgY29uZmlnOiB0aGlzLnBheWxvYWQuY29uZmlnLFxuICAgIGRhdGE6IGRvYyxcbiAgICBmaWVsZHM6IGNvbGxlY3Rpb25Db25maWcuZmllbGRzLFxuICB9KVxufVxuIl0sIm5hbWVzIjpbImZpbmRPbmUiLCJjb2xsZWN0aW9uIiwibG9jYWxlIiwicmVxIiwid2hlcmUiLCJpbmNvbWluZ1doZXJlIiwiZGIiLCJzZXNzaW9ucyIsInRyYW5zYWN0aW9uSUQiLCJjb2xsZWN0aW9uQ29uZmlnIiwicGF5bG9hZCIsImNvbGxlY3Rpb25zIiwiY29uZmlnIiwidGFibGVOYW1lIiwidG9TbmFrZUNhc2UiLCJidWlsZFF1ZXJ5IiwiYWRhcHRlciIsImZpZWxkcyIsImZpbmRNYW55QXJncyIsImJ1aWxkRmluZE1hbnlBcmdzIiwiZGVwdGgiLCJkb2MiLCJxdWVyeSIsImZpbmRGaXJzdCIsInRyYW5zZm9ybSIsImRhdGEiXSwibWFwcGluZ3MiOiI7Ozs7K0JBV3NCQTs7O2VBQUFBOzs7b0VBUkU7bUNBSVU7bUVBQ1g7c0JBQ0c7Ozs7OztBQUVuQixlQUFlQSxRQUVwQixFQUFFQyxVQUFVLEVBQUVDLE1BQU0sRUFBRUMsTUFBTSxDQUFDLENBQW1CLEVBQUVDLE9BQU9DLGFBQWEsRUFBZTtJQUVyRixNQUFNQyxLQUFLLElBQUksQ0FBQ0MsUUFBUSxDQUFDSixJQUFJSyxhQUFhLENBQUMsRUFBRUYsTUFBTSxJQUFJLENBQUNBLEVBQUU7SUFDMUQsTUFBTUcsbUJBQThDLElBQUksQ0FBQ0MsT0FBTyxDQUFDQyxXQUFXLENBQUNWLFdBQVcsQ0FBQ1csTUFBTTtJQUMvRixNQUFNQyxZQUFZQyxJQUFBQSxvQkFBVyxFQUFDYjtJQUU5QixNQUFNLEVBQUVHLEtBQUssRUFBRSxHQUFHLE1BQU1XLElBQUFBLG1CQUFVLEVBQUM7UUFDakNDLFNBQVMsSUFBSTtRQUNiQyxRQUFRUixpQkFBaUJRLE1BQU07UUFDL0JmO1FBQ0FXO1FBQ0FULE9BQU9DO0lBQ1Q7SUFFQSxNQUFNYSxlQUFlQyxJQUFBQSxvQ0FBaUIsRUFBQztRQUNyQ0gsU0FBUyxJQUFJO1FBQ2JJLE9BQU87UUFDUEgsUUFBUVIsaUJBQWlCUSxNQUFNO1FBQy9CSjtJQUNGO0lBRUFLLGFBQWFkLEtBQUssR0FBR0E7SUFFckIsTUFBTWlCLE1BQU0sTUFBTWYsR0FBR2dCLEtBQUssQ0FBQ1QsVUFBVSxDQUFDVSxTQUFTLENBQUNMO0lBRWhELElBQUksQ0FBQ0csS0FBSztRQUNSLE9BQU87SUFDVDtJQUVBLE9BQU9HLElBQUFBLGVBQVMsRUFBSTtRQUNsQlosUUFBUSxJQUFJLENBQUNGLE9BQU8sQ0FBQ0UsTUFBTTtRQUMzQmEsTUFBTUo7UUFDTkosUUFBUVIsaUJBQWlCUSxNQUFNO0lBQ2pDO0FBQ0YifQ==
@@ -0,0 +1,39 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", {
3
+ value: true
4
+ });
5
+ Object.defineProperty(exports, "findVersions", {
6
+ enumerable: true,
7
+ get: function() {
8
+ return findVersions;
9
+ }
10
+ });
11
+ const _versions = require("payload/versions");
12
+ const _tosnakecase = /*#__PURE__*/ _interop_require_default(require("to-snake-case"));
13
+ const _findMany = require("./find/findMany");
14
+ function _interop_require_default(obj) {
15
+ return obj && obj.__esModule ? obj : {
16
+ default: obj
17
+ };
18
+ }
19
+ const findVersions = async function findVersions({ collection, limit, locale, page, pagination, req = {}, skip, sort: sortArg, where }) {
20
+ const collectionConfig = this.payload.collections[collection].config;
21
+ const sort = typeof sortArg === 'string' ? sortArg : collectionConfig.defaultSort;
22
+ const tableName = `_${(0, _tosnakecase.default)(collection)}_v`;
23
+ const fields = (0, _versions.buildVersionCollectionFields)(collectionConfig);
24
+ return (0, _findMany.findMany)({
25
+ adapter: this,
26
+ fields,
27
+ limit,
28
+ locale,
29
+ page,
30
+ pagination,
31
+ req,
32
+ skip,
33
+ sort,
34
+ tableName,
35
+ where
36
+ });
37
+ };
38
+
39
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uL3NyYy9maW5kVmVyc2lvbnMudHMiXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHR5cGUgeyBGaW5kVmVyc2lvbnMgfSBmcm9tICdwYXlsb2FkL2RhdGFiYXNlJ1xuaW1wb3J0IHR5cGUgeyBQYXlsb2FkUmVxdWVzdCwgU2FuaXRpemVkQ29sbGVjdGlvbkNvbmZpZyB9IGZyb20gJ3BheWxvYWQvdHlwZXMnXG5cbmltcG9ydCB7IGJ1aWxkVmVyc2lvbkNvbGxlY3Rpb25GaWVsZHMgfSBmcm9tICdwYXlsb2FkL3ZlcnNpb25zJ1xuaW1wb3J0IHRvU25ha2VDYXNlIGZyb20gJ3RvLXNuYWtlLWNhc2UnXG5cbmltcG9ydCB0eXBlIHsgUG9zdGdyZXNBZGFwdGVyIH0gZnJvbSAnLi90eXBlcydcblxuaW1wb3J0IHsgZmluZE1hbnkgfSBmcm9tICcuL2ZpbmQvZmluZE1hbnknXG5cbmV4cG9ydCBjb25zdCBmaW5kVmVyc2lvbnM6IEZpbmRWZXJzaW9ucyA9IGFzeW5jIGZ1bmN0aW9uIGZpbmRWZXJzaW9ucyhcbiAgdGhpczogUG9zdGdyZXNBZGFwdGVyLFxuICB7XG4gICAgY29sbGVjdGlvbixcbiAgICBsaW1pdCxcbiAgICBsb2NhbGUsXG4gICAgcGFnZSxcbiAgICBwYWdpbmF0aW9uLFxuICAgIHJlcSA9IHt9IGFzIFBheWxvYWRSZXF1ZXN0LFxuICAgIHNraXAsXG4gICAgc29ydDogc29ydEFyZyxcbiAgICB3aGVyZSxcbiAgfSxcbikge1xuICBjb25zdCBjb2xsZWN0aW9uQ29uZmlnOiBTYW5pdGl6ZWRDb2xsZWN0aW9uQ29uZmlnID0gdGhpcy5wYXlsb2FkLmNvbGxlY3Rpb25zW2NvbGxlY3Rpb25dLmNvbmZpZ1xuICBjb25zdCBzb3J0ID0gdHlwZW9mIHNvcnRBcmcgPT09ICdzdHJpbmcnID8gc29ydEFyZyA6IGNvbGxlY3Rpb25Db25maWcuZGVmYXVsdFNvcnRcblxuICBjb25zdCB0YWJsZU5hbWUgPSBgXyR7dG9TbmFrZUNhc2UoY29sbGVjdGlvbil9X3ZgXG4gIGNvbnN0IGZpZWxkcyA9IGJ1aWxkVmVyc2lvbkNvbGxlY3Rpb25GaWVsZHMoY29sbGVjdGlvbkNvbmZpZylcblxuICByZXR1cm4gZmluZE1hbnkoe1xuICAgIGFkYXB0ZXI6IHRoaXMsXG4gICAgZmllbGRzLFxuICAgIGxpbWl0LFxuICAgIGxvY2FsZSxcbiAgICBwYWdlLFxuICAgIHBhZ2luYXRpb24sXG4gICAgcmVxLFxuICAgIHNraXAsXG4gICAgc29ydCxcbiAgICB0YWJsZU5hbWUsXG4gICAgd2hlcmUsXG4gIH0pXG59XG4iXSwibmFtZXMiOlsiZmluZFZlcnNpb25zIiwiY29sbGVjdGlvbiIsImxpbWl0IiwibG9jYWxlIiwicGFnZSIsInBhZ2luYXRpb24iLCJyZXEiLCJza2lwIiwic29ydCIsInNvcnRBcmciLCJ3aGVyZSIsImNvbGxlY3Rpb25Db25maWciLCJwYXlsb2FkIiwiY29sbGVjdGlvbnMiLCJjb25maWciLCJkZWZhdWx0U29ydCIsInRhYmxlTmFtZSIsInRvU25ha2VDYXNlIiwiZmllbGRzIiwiYnVpbGRWZXJzaW9uQ29sbGVjdGlvbkZpZWxkcyIsImZpbmRNYW55IiwiYWRhcHRlciJdLCJtYXBwaW5ncyI6Ijs7OzsrQkFVYUE7OztlQUFBQTs7OzBCQVBnQztvRUFDckI7MEJBSUM7Ozs7OztBQUVsQixNQUFNQSxlQUE2QixlQUFlQSxhQUV2RCxFQUNFQyxVQUFVLEVBQ1ZDLEtBQUssRUFDTEMsTUFBTSxFQUNOQyxJQUFJLEVBQ0pDLFVBQVUsRUFDVkMsTUFBTSxDQUFDLENBQW1CLEVBQzFCQyxJQUFJLEVBQ0pDLE1BQU1DLE9BQU8sRUFDYkMsS0FBSyxFQUNOO0lBRUQsTUFBTUMsbUJBQThDLElBQUksQ0FBQ0MsT0FBTyxDQUFDQyxXQUFXLENBQUNaLFdBQVcsQ0FBQ2EsTUFBTTtJQUMvRixNQUFNTixPQUFPLE9BQU9DLFlBQVksV0FBV0EsVUFBVUUsaUJBQWlCSSxXQUFXO0lBRWpGLE1BQU1DLFlBQVksQ0FBQyxDQUFDLEVBQUVDLElBQUFBLG9CQUFXLEVBQUNoQixZQUFZLEVBQUUsQ0FBQztJQUNqRCxNQUFNaUIsU0FBU0MsSUFBQUEsc0NBQTRCLEVBQUNSO0lBRTVDLE9BQU9TLElBQUFBLGtCQUFRLEVBQUM7UUFDZEMsU0FBUyxJQUFJO1FBQ2JIO1FBQ0FoQjtRQUNBQztRQUNBQztRQUNBQztRQUNBQztRQUNBQztRQUNBQztRQUNBUTtRQUNBTjtJQUNGO0FBQ0YifQ==