@payloadcms/db-mongodb 1.0.0-beta.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (124) hide show
  1. package/dist/connect.d.ts +3 -0
  2. package/dist/connect.d.ts.map +1 -0
  3. package/dist/connect.js +63 -0
  4. package/dist/create.d.ts +3 -0
  5. package/dist/create.d.ts.map +1 -0
  6. package/dist/create.js +29 -0
  7. package/dist/createGlobal.d.ts +3 -0
  8. package/dist/createGlobal.d.ts.map +1 -0
  9. package/dist/createGlobal.js +35 -0
  10. package/dist/createGlobalVersion.d.ts +3 -0
  11. package/dist/createGlobalVersion.d.ts.map +1 -0
  12. package/dist/createGlobalVersion.js +58 -0
  13. package/dist/createVersion.d.ts +3 -0
  14. package/dist/createVersion.d.ts.map +1 -0
  15. package/dist/createVersion.js +58 -0
  16. package/dist/deleteMany.d.ts +3 -0
  17. package/dist/deleteMany.d.ts.map +1 -0
  18. package/dist/deleteMany.js +25 -0
  19. package/dist/deleteOne.d.ts +3 -0
  20. package/dist/deleteOne.d.ts.map +1 -0
  21. package/dist/deleteOne.js +33 -0
  22. package/dist/deleteVersions.d.ts +3 -0
  23. package/dist/deleteVersions.d.ts.map +1 -0
  24. package/dist/deleteVersions.js +26 -0
  25. package/dist/destroy.d.ts +3 -0
  26. package/dist/destroy.d.ts.map +1 -0
  27. package/dist/destroy.js +27 -0
  28. package/dist/find.d.ts +3 -0
  29. package/dist/find.d.ts.map +1 -0
  30. package/dist/find.js +71 -0
  31. package/dist/findGlobal.d.ts +3 -0
  32. package/dist/findGlobal.d.ts.map +1 -0
  33. package/dist/findGlobal.js +48 -0
  34. package/dist/findGlobalVersions.d.ts +3 -0
  35. package/dist/findGlobalVersions.d.ts.map +1 -0
  36. package/dist/findGlobalVersions.js +78 -0
  37. package/dist/findOne.d.ts +3 -0
  38. package/dist/findOne.d.ts.map +1 -0
  39. package/dist/findOne.js +40 -0
  40. package/dist/findVersions.d.ts +3 -0
  41. package/dist/findVersions.d.ts.map +1 -0
  42. package/dist/findVersions.js +77 -0
  43. package/dist/index.d.ts +34 -0
  44. package/dist/index.d.ts.map +1 -0
  45. package/dist/index.js +91 -0
  46. package/dist/init.d.ts +3 -0
  47. package/dist/init.d.ts.map +1 -0
  48. package/dist/init.js +98 -0
  49. package/dist/mock.js +13 -0
  50. package/dist/models/buildCollectionSchema.d.ts +6 -0
  51. package/dist/models/buildCollectionSchema.d.ts.map +1 -0
  52. package/dist/models/buildCollectionSchema.js +51 -0
  53. package/dist/models/buildGlobalModel.d.ts +4 -0
  54. package/dist/models/buildGlobalModel.d.ts.map +1 -0
  55. package/dist/models/buildGlobalModel.js +41 -0
  56. package/dist/models/buildSchema.d.ts +14 -0
  57. package/dist/models/buildSchema.d.ts.map +1 -0
  58. package/dist/models/buildSchema.js +438 -0
  59. package/dist/queries/buildAndOrConditions.d.ts +11 -0
  60. package/dist/queries/buildAndOrConditions.d.ts.map +1 -0
  61. package/dist/queries/buildAndOrConditions.js +37 -0
  62. package/dist/queries/buildQuery.d.ts +15 -0
  63. package/dist/queries/buildQuery.d.ts.map +1 -0
  64. package/dist/queries/buildQuery.js +49 -0
  65. package/dist/queries/buildSearchParams.d.ts +21 -0
  66. package/dist/queries/buildSearchParams.d.ts.map +1 -0
  67. package/dist/queries/buildSearchParams.js +219 -0
  68. package/dist/queries/buildSortParam.d.ts +18 -0
  69. package/dist/queries/buildSortParam.d.ts.map +1 -0
  70. package/dist/queries/buildSortParam.js +42 -0
  71. package/dist/queries/getLocalizedSortProperty.d.ts +12 -0
  72. package/dist/queries/getLocalizedSortProperty.d.ts.map +1 -0
  73. package/dist/queries/getLocalizedSortProperty.js +76 -0
  74. package/dist/queries/getLocalizedSortProperty.spec.js +195 -0
  75. package/dist/queries/mock.js +3 -0
  76. package/dist/queries/operatorMap.d.ts +16 -0
  77. package/dist/queries/operatorMap.d.ts.map +1 -0
  78. package/dist/queries/operatorMap.js +27 -0
  79. package/dist/queries/parseParams.d.ts +12 -0
  80. package/dist/queries/parseParams.d.ts.map +1 -0
  81. package/dist/queries/parseParams.js +80 -0
  82. package/dist/queries/sanitizeQueryValue.d.ts +11 -0
  83. package/dist/queries/sanitizeQueryValue.d.ts.map +1 -0
  84. package/dist/queries/sanitizeQueryValue.js +128 -0
  85. package/dist/queryDrafts.d.ts +3 -0
  86. package/dist/queryDrafts.d.ts.map +1 -0
  87. package/dist/queryDrafts.js +82 -0
  88. package/dist/testCredentials.d.ts +8 -0
  89. package/dist/testCredentials.d.ts.map +1 -0
  90. package/dist/testCredentials.js +30 -0
  91. package/dist/transactions/beginTransaction.d.ts +3 -0
  92. package/dist/transactions/beginTransaction.d.ts.map +1 -0
  93. package/dist/transactions/beginTransaction.js +38 -0
  94. package/dist/transactions/commitTransaction.d.ts +3 -0
  95. package/dist/transactions/commitTransaction.d.ts.map +1 -0
  96. package/dist/transactions/commitTransaction.js +24 -0
  97. package/dist/transactions/rollbackTransaction.d.ts +3 -0
  98. package/dist/transactions/rollbackTransaction.d.ts.map +1 -0
  99. package/dist/transactions/rollbackTransaction.js +21 -0
  100. package/dist/types.d.ts +70 -0
  101. package/dist/types.d.ts.map +1 -0
  102. package/dist/types.js +6 -0
  103. package/dist/updateGlobal.d.ts +3 -0
  104. package/dist/updateGlobal.d.ts.map +1 -0
  105. package/dist/updateGlobal.js +36 -0
  106. package/dist/updateGlobalVersion.d.ts +5 -0
  107. package/dist/updateGlobalVersion.d.ts.map +1 -0
  108. package/dist/updateGlobalVersion.js +35 -0
  109. package/dist/updateOne.d.ts +3 -0
  110. package/dist/updateOne.d.ts.map +1 -0
  111. package/dist/updateOne.js +55 -0
  112. package/dist/updateVersion.d.ts +3 -0
  113. package/dist/updateVersion.d.ts.map +1 -0
  114. package/dist/updateVersion.js +35 -0
  115. package/dist/utilities/sanitizeInternalFields.d.ts +3 -0
  116. package/dist/utilities/sanitizeInternalFields.d.ts.map +1 -0
  117. package/dist/utilities/sanitizeInternalFields.js +31 -0
  118. package/dist/webpack.d.ts +3 -0
  119. package/dist/webpack.d.ts.map +1 -0
  120. package/dist/webpack.js +30 -0
  121. package/dist/withSession.d.ts +10 -0
  122. package/dist/withSession.d.ts.map +1 -0
  123. package/dist/withSession.js +17 -0
  124. package/package.json +43 -0
@@ -0,0 +1,195 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", {
3
+ value: true
4
+ });
5
+ const _config = require("payload/config");
6
+ const _getLocalizedSortProperty = require("./getLocalizedSortProperty");
7
+ const config = {
8
+ localization: {
9
+ locales: [
10
+ 'en',
11
+ 'es'
12
+ ]
13
+ }
14
+ };
15
+ describe('get localized sort property', ()=>{
16
+ it('passes through a non-localized sort property', ()=>{
17
+ const result = (0, _getLocalizedSortProperty.getLocalizedSortProperty)({
18
+ segments: [
19
+ 'title'
20
+ ],
21
+ config: (0, _config.sanitizeConfig)(config),
22
+ fields: [
23
+ {
24
+ name: 'title',
25
+ type: 'text'
26
+ }
27
+ ],
28
+ locale: 'en'
29
+ });
30
+ expect(result).toStrictEqual('title');
31
+ });
32
+ it('properly localizes an un-localized sort property', ()=>{
33
+ const result = (0, _getLocalizedSortProperty.getLocalizedSortProperty)({
34
+ segments: [
35
+ 'title'
36
+ ],
37
+ config: (0, _config.sanitizeConfig)(config),
38
+ fields: [
39
+ {
40
+ name: 'title',
41
+ type: 'text',
42
+ localized: true
43
+ }
44
+ ],
45
+ locale: 'en'
46
+ });
47
+ expect(result).toStrictEqual('title.en');
48
+ });
49
+ it('keeps specifically asked-for localized sort properties', ()=>{
50
+ const result = (0, _getLocalizedSortProperty.getLocalizedSortProperty)({
51
+ segments: [
52
+ 'title',
53
+ 'es'
54
+ ],
55
+ config: (0, _config.sanitizeConfig)(config),
56
+ fields: [
57
+ {
58
+ name: 'title',
59
+ type: 'text',
60
+ localized: true
61
+ }
62
+ ],
63
+ locale: 'en'
64
+ });
65
+ expect(result).toStrictEqual('title.es');
66
+ });
67
+ it('properly localizes nested sort properties', ()=>{
68
+ const result = (0, _getLocalizedSortProperty.getLocalizedSortProperty)({
69
+ segments: [
70
+ 'group',
71
+ 'title'
72
+ ],
73
+ config: (0, _config.sanitizeConfig)(config),
74
+ fields: [
75
+ {
76
+ name: 'group',
77
+ type: 'group',
78
+ fields: [
79
+ {
80
+ name: 'title',
81
+ type: 'text',
82
+ localized: true
83
+ }
84
+ ]
85
+ }
86
+ ],
87
+ locale: 'en'
88
+ });
89
+ expect(result).toStrictEqual('group.title.en');
90
+ });
91
+ it('keeps requested locale with nested sort properties', ()=>{
92
+ const result = (0, _getLocalizedSortProperty.getLocalizedSortProperty)({
93
+ segments: [
94
+ 'group',
95
+ 'title',
96
+ 'es'
97
+ ],
98
+ config: (0, _config.sanitizeConfig)(config),
99
+ fields: [
100
+ {
101
+ name: 'group',
102
+ type: 'group',
103
+ fields: [
104
+ {
105
+ name: 'title',
106
+ type: 'text',
107
+ localized: true
108
+ }
109
+ ]
110
+ }
111
+ ],
112
+ locale: 'en'
113
+ });
114
+ expect(result).toStrictEqual('group.title.es');
115
+ });
116
+ it('properly localizes field within row', ()=>{
117
+ const result = (0, _getLocalizedSortProperty.getLocalizedSortProperty)({
118
+ segments: [
119
+ 'title'
120
+ ],
121
+ config: (0, _config.sanitizeConfig)(config),
122
+ fields: [
123
+ {
124
+ type: 'row',
125
+ fields: [
126
+ {
127
+ name: 'title',
128
+ type: 'text',
129
+ localized: true
130
+ }
131
+ ]
132
+ }
133
+ ],
134
+ locale: 'en'
135
+ });
136
+ expect(result).toStrictEqual('title.en');
137
+ });
138
+ it('properly localizes field within named tab', ()=>{
139
+ const result = (0, _getLocalizedSortProperty.getLocalizedSortProperty)({
140
+ segments: [
141
+ 'tab',
142
+ 'title'
143
+ ],
144
+ config: (0, _config.sanitizeConfig)(config),
145
+ fields: [
146
+ {
147
+ type: 'tabs',
148
+ tabs: [
149
+ {
150
+ name: 'tab',
151
+ fields: [
152
+ {
153
+ name: 'title',
154
+ type: 'text',
155
+ localized: true
156
+ }
157
+ ]
158
+ }
159
+ ]
160
+ }
161
+ ],
162
+ locale: 'en'
163
+ });
164
+ expect(result).toStrictEqual('tab.title.en');
165
+ });
166
+ it('properly localizes field within unnamed tab', ()=>{
167
+ const result = (0, _getLocalizedSortProperty.getLocalizedSortProperty)({
168
+ segments: [
169
+ 'title'
170
+ ],
171
+ config: (0, _config.sanitizeConfig)(config),
172
+ fields: [
173
+ {
174
+ type: 'tabs',
175
+ tabs: [
176
+ {
177
+ label: 'Tab',
178
+ fields: [
179
+ {
180
+ name: 'title',
181
+ type: 'text',
182
+ localized: true
183
+ }
184
+ ]
185
+ }
186
+ ]
187
+ }
188
+ ],
189
+ locale: 'en'
190
+ });
191
+ expect(result).toStrictEqual('title.en');
192
+ });
193
+ });
194
+
195
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../src/queries/getLocalizedSortProperty.spec.ts"],"sourcesContent":["import { sanitizeConfig } from 'payload/config'\nimport { Config } from 'payload/config'\nimport { getLocalizedSortProperty } from './getLocalizedSortProperty'\n\nconst config = {\n  localization: {\n    locales: ['en', 'es'],\n  },\n} as Config\n\ndescribe('get localized sort property', () => {\n  it('passes through a non-localized sort property', () => {\n    const result = getLocalizedSortProperty({\n      segments: ['title'],\n      config: sanitizeConfig(config),\n      fields: [\n        {\n          name: 'title',\n          type: 'text',\n        },\n      ],\n      locale: 'en',\n    })\n\n    expect(result).toStrictEqual('title')\n  })\n\n  it('properly localizes an un-localized sort property', () => {\n    const result = getLocalizedSortProperty({\n      segments: ['title'],\n      config: sanitizeConfig(config),\n      fields: [\n        {\n          name: 'title',\n          type: 'text',\n          localized: true,\n        },\n      ],\n      locale: 'en',\n    })\n\n    expect(result).toStrictEqual('title.en')\n  })\n\n  it('keeps specifically asked-for localized sort properties', () => {\n    const result = getLocalizedSortProperty({\n      segments: ['title', 'es'],\n      config: sanitizeConfig(config),\n      fields: [\n        {\n          name: 'title',\n          type: 'text',\n          localized: true,\n        },\n      ],\n      locale: 'en',\n    })\n\n    expect(result).toStrictEqual('title.es')\n  })\n\n  it('properly localizes nested sort properties', () => {\n    const result = getLocalizedSortProperty({\n      segments: ['group', 'title'],\n      config: sanitizeConfig(config),\n      fields: [\n        {\n          name: 'group',\n          type: 'group',\n          fields: [\n            {\n              name: 'title',\n              type: 'text',\n              localized: true,\n            },\n          ],\n        },\n      ],\n      locale: 'en',\n    })\n\n    expect(result).toStrictEqual('group.title.en')\n  })\n\n  it('keeps requested locale with nested sort properties', () => {\n    const result = getLocalizedSortProperty({\n      segments: ['group', 'title', 'es'],\n      config: sanitizeConfig(config),\n      fields: [\n        {\n          name: 'group',\n          type: 'group',\n          fields: [\n            {\n              name: 'title',\n              type: 'text',\n              localized: true,\n            },\n          ],\n        },\n      ],\n      locale: 'en',\n    })\n\n    expect(result).toStrictEqual('group.title.es')\n  })\n\n  it('properly localizes field within row', () => {\n    const result = getLocalizedSortProperty({\n      segments: ['title'],\n      config: sanitizeConfig(config),\n      fields: [\n        {\n          type: 'row',\n          fields: [\n            {\n              name: 'title',\n              type: 'text',\n              localized: true,\n            },\n          ],\n        },\n      ],\n      locale: 'en',\n    })\n\n    expect(result).toStrictEqual('title.en')\n  })\n\n  it('properly localizes field within named tab', () => {\n    const result = getLocalizedSortProperty({\n      segments: ['tab', 'title'],\n      config: sanitizeConfig(config),\n      fields: [\n        {\n          type: 'tabs',\n          tabs: [\n            {\n              name: 'tab',\n              fields: [\n                {\n                  name: 'title',\n                  type: 'text',\n                  localized: true,\n                },\n              ],\n            },\n          ],\n        },\n      ],\n      locale: 'en',\n    })\n\n    expect(result).toStrictEqual('tab.title.en')\n  })\n\n  it('properly localizes field within unnamed tab', () => {\n    const result = getLocalizedSortProperty({\n      segments: ['title'],\n      config: sanitizeConfig(config),\n      fields: [\n        {\n          type: 'tabs',\n          tabs: [\n            {\n              label: 'Tab',\n              fields: [\n                {\n                  name: 'title',\n                  type: 'text',\n                  localized: true,\n                },\n              ],\n            },\n          ],\n        },\n      ],\n      locale: 'en',\n    })\n\n    expect(result).toStrictEqual('title.en')\n  })\n})\n"],"names":["config","localization","locales","describe","it","result","getLocalizedSortProperty","segments","sanitizeConfig","fields","name","type","locale","expect","toStrictEqual","localized","tabs","label"],"mappings":"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"}
@@ -0,0 +1,3 @@
1
+ "use strict";
2
+
3
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IiJ9
@@ -0,0 +1,16 @@
1
+ export declare const operatorMap: {
2
+ all: string;
3
+ equals: string;
4
+ exists: string;
5
+ greater_than: string;
6
+ greater_than_equal: string;
7
+ in: string;
8
+ intersects: string;
9
+ less_than: string;
10
+ less_than_equal: string;
11
+ near: string;
12
+ not_equals: string;
13
+ not_in: string;
14
+ within: string;
15
+ };
16
+ //# sourceMappingURL=operatorMap.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"operatorMap.d.ts","sourceRoot":"","sources":["../../src/queries/operatorMap.ts"],"names":[],"mappings":"AAAA,eAAO,MAAM,WAAW;;;;;;;;;;;;;;CAcvB,CAAA"}
@@ -0,0 +1,27 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", {
3
+ value: true
4
+ });
5
+ Object.defineProperty(exports, "operatorMap", {
6
+ enumerable: true,
7
+ get: function() {
8
+ return operatorMap;
9
+ }
10
+ });
11
+ const operatorMap = {
12
+ all: '$all',
13
+ equals: '$eq',
14
+ exists: '$exists',
15
+ greater_than: '$gt',
16
+ greater_than_equal: '$gte',
17
+ in: '$in',
18
+ intersects: '$geoIntersects',
19
+ less_than: '$lt',
20
+ less_than_equal: '$lte',
21
+ near: '$near',
22
+ not_equals: '$ne',
23
+ not_in: '$nin',
24
+ within: '$geoWithin'
25
+ };
26
+
27
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9xdWVyaWVzL29wZXJhdG9yTWFwLnRzIl0sInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCBjb25zdCBvcGVyYXRvck1hcCA9IHtcbiAgYWxsOiAnJGFsbCcsXG4gIGVxdWFsczogJyRlcScsXG4gIGV4aXN0czogJyRleGlzdHMnLFxuICBncmVhdGVyX3RoYW46ICckZ3QnLFxuICBncmVhdGVyX3RoYW5fZXF1YWw6ICckZ3RlJyxcbiAgaW46ICckaW4nLFxuICBpbnRlcnNlY3RzOiAnJGdlb0ludGVyc2VjdHMnLFxuICBsZXNzX3RoYW46ICckbHQnLFxuICBsZXNzX3RoYW5fZXF1YWw6ICckbHRlJyxcbiAgbmVhcjogJyRuZWFyJyxcbiAgbm90X2VxdWFsczogJyRuZScsXG4gIG5vdF9pbjogJyRuaW4nLFxuICB3aXRoaW46ICckZ2VvV2l0aGluJyxcbn1cbiJdLCJuYW1lcyI6WyJvcGVyYXRvck1hcCIsImFsbCIsImVxdWFscyIsImV4aXN0cyIsImdyZWF0ZXJfdGhhbiIsImdyZWF0ZXJfdGhhbl9lcXVhbCIsImluIiwiaW50ZXJzZWN0cyIsImxlc3NfdGhhbiIsImxlc3NfdGhhbl9lcXVhbCIsIm5lYXIiLCJub3RfZXF1YWxzIiwibm90X2luIiwid2l0aGluIl0sIm1hcHBpbmdzIjoiOzs7OytCQUFhQTs7O2VBQUFBOzs7QUFBTixNQUFNQSxjQUFjO0lBQ3pCQyxLQUFLO0lBQ0xDLFFBQVE7SUFDUkMsUUFBUTtJQUNSQyxjQUFjO0lBQ2RDLG9CQUFvQjtJQUNwQkMsSUFBSTtJQUNKQyxZQUFZO0lBQ1pDLFdBQVc7SUFDWEMsaUJBQWlCO0lBQ2pCQyxNQUFNO0lBQ05DLFlBQVk7SUFDWkMsUUFBUTtJQUNSQyxRQUFRO0FBQ1YifQ==
@@ -0,0 +1,12 @@
1
+ import type { Payload } from 'payload';
2
+ import type { Where } from 'payload/types';
3
+ import type { Field } from 'payload/types';
4
+ export declare function parseParams({ collectionSlug, fields, globalSlug, locale, payload, where, }: {
5
+ collectionSlug?: string;
6
+ fields: Field[];
7
+ globalSlug?: string;
8
+ locale: string;
9
+ payload: Payload;
10
+ where: Where;
11
+ }): Promise<Record<string, unknown>>;
12
+ //# sourceMappingURL=parseParams.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"parseParams.d.ts","sourceRoot":"","sources":["../../src/queries/parseParams.ts"],"names":[],"mappings":"AAGA,OAAO,KAAK,EAAE,OAAO,EAAE,MAAM,SAAS,CAAA;AACtC,OAAO,KAAK,EAAY,KAAK,EAAE,MAAM,eAAe,CAAA;AACpD,OAAO,KAAK,EAAE,KAAK,EAAE,MAAM,eAAe,CAAA;AAS1C,wBAAsB,WAAW,CAAC,EAChC,cAAc,EACd,MAAM,EACN,UAAU,EACV,MAAM,EACN,OAAO,EACP,KAAK,GACN,EAAE;IACD,cAAc,CAAC,EAAE,MAAM,CAAA;IACvB,MAAM,EAAE,KAAK,EAAE,CAAA;IACf,UAAU,CAAC,EAAE,MAAM,CAAA;IACnB,MAAM,EAAE,MAAM,CAAA;IACd,OAAO,EAAE,OAAO,CAAA;IAChB,KAAK,EAAE,KAAK,CAAA;CACb,GAAG,OAAO,CAAC,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC,CA0DnC"}
@@ -0,0 +1,80 @@
1
+ /* eslint-disable no-restricted-syntax */ /* 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 _deepmerge = /*#__PURE__*/ _interop_require_default(require("deepmerge"));
12
+ const _types = require("payload/types");
13
+ const _utilities = require("payload/utilities");
14
+ const _buildAndOrConditions = require("./buildAndOrConditions");
15
+ const _buildSearchParams = require("./buildSearchParams");
16
+ function _interop_require_default(obj) {
17
+ return obj && obj.__esModule ? obj : {
18
+ default: obj
19
+ };
20
+ }
21
+ async function parseParams({ collectionSlug, fields, globalSlug, locale, payload, where }) {
22
+ let result = {};
23
+ if (typeof where === 'object') {
24
+ // We need to determine if the whereKey is an AND, OR, or a schema path
25
+ for (const relationOrPath of Object.keys(where)){
26
+ const condition = where[relationOrPath];
27
+ let conditionOperator;
28
+ if (relationOrPath.toLowerCase() === 'and') {
29
+ conditionOperator = '$and';
30
+ } else if (relationOrPath.toLowerCase() === 'or') {
31
+ conditionOperator = '$or';
32
+ }
33
+ if (Array.isArray(condition)) {
34
+ const builtConditions = await (0, _buildAndOrConditions.buildAndOrConditions)({
35
+ collectionSlug,
36
+ fields,
37
+ globalSlug,
38
+ locale,
39
+ payload,
40
+ where: condition
41
+ });
42
+ if (builtConditions.length > 0) result[conditionOperator] = builtConditions;
43
+ } else {
44
+ // It's a path - and there can be multiple comparisons on a single path.
45
+ // For example - title like 'test' and title not equal to 'tester'
46
+ // So we need to loop on keys again here to handle each operator independently
47
+ const pathOperators = where[relationOrPath];
48
+ if (typeof pathOperators === 'object') {
49
+ for (const operator of Object.keys(pathOperators)){
50
+ if (_types.validOperators.includes(operator)) {
51
+ const searchParam = await (0, _buildSearchParams.buildSearchParam)({
52
+ collectionSlug,
53
+ fields,
54
+ globalSlug,
55
+ incomingPath: relationOrPath,
56
+ locale,
57
+ operator,
58
+ payload,
59
+ val: pathOperators[operator]
60
+ });
61
+ if (searchParam?.value && searchParam?.path) {
62
+ result = {
63
+ ...result,
64
+ [searchParam.path]: searchParam.value
65
+ };
66
+ } else if (typeof searchParam?.value === 'object') {
67
+ result = (0, _deepmerge.default)(result, searchParam.value, {
68
+ arrayMerge: _utilities.combineMerge
69
+ });
70
+ }
71
+ }
72
+ }
73
+ }
74
+ }
75
+ }
76
+ }
77
+ return result;
78
+ }
79
+
80
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9xdWVyaWVzL3BhcnNlUGFyYW1zLnRzIl0sInNvdXJjZXNDb250ZW50IjpbIi8qIGVzbGludC1kaXNhYmxlIG5vLXJlc3RyaWN0ZWQtc3ludGF4ICovXG4vKiBlc2xpbnQtZGlzYWJsZSBuby1hd2FpdC1pbi1sb29wICovXG5pbXBvcnQgdHlwZSB7IEZpbHRlclF1ZXJ5IH0gZnJvbSAnbW9uZ29vc2UnXG5pbXBvcnQgdHlwZSB7IFBheWxvYWQgfSBmcm9tICdwYXlsb2FkJ1xuaW1wb3J0IHR5cGUgeyBPcGVyYXRvciwgV2hlcmUgfSBmcm9tICdwYXlsb2FkL3R5cGVzJ1xuaW1wb3J0IHR5cGUgeyBGaWVsZCB9IGZyb20gJ3BheWxvYWQvdHlwZXMnXG5cbmltcG9ydCBkZWVwbWVyZ2UgZnJvbSAnZGVlcG1lcmdlJ1xuaW1wb3J0IHsgdmFsaWRPcGVyYXRvcnMgfSBmcm9tICdwYXlsb2FkL3R5cGVzJ1xuaW1wb3J0IHsgY29tYmluZU1lcmdlIH0gZnJvbSAncGF5bG9hZC91dGlsaXRpZXMnXG5cbmltcG9ydCB7IGJ1aWxkQW5kT3JDb25kaXRpb25zIH0gZnJvbSAnLi9idWlsZEFuZE9yQ29uZGl0aW9ucydcbmltcG9ydCB7IGJ1aWxkU2VhcmNoUGFyYW0gfSBmcm9tICcuL2J1aWxkU2VhcmNoUGFyYW1zJ1xuXG5leHBvcnQgYXN5bmMgZnVuY3Rpb24gcGFyc2VQYXJhbXMoe1xuICBjb2xsZWN0aW9uU2x1ZyxcbiAgZmllbGRzLFxuICBnbG9iYWxTbHVnLFxuICBsb2NhbGUsXG4gIHBheWxvYWQsXG4gIHdoZXJlLFxufToge1xuICBjb2xsZWN0aW9uU2x1Zz86IHN0cmluZ1xuICBmaWVsZHM6IEZpZWxkW11cbiAgZ2xvYmFsU2x1Zz86IHN0cmluZ1xuICBsb2NhbGU6IHN0cmluZ1xuICBwYXlsb2FkOiBQYXlsb2FkXG4gIHdoZXJlOiBXaGVyZVxufSk6IFByb21pc2U8UmVjb3JkPHN0cmluZywgdW5rbm93bj4+IHtcbiAgbGV0IHJlc3VsdCA9IHt9IGFzIEZpbHRlclF1ZXJ5PGFueT5cblxuICBpZiAodHlwZW9mIHdoZXJlID09PSAnb2JqZWN0Jykge1xuICAgIC8vIFdlIG5lZWQgdG8gZGV0ZXJtaW5lIGlmIHRoZSB3aGVyZUtleSBpcyBhbiBBTkQsIE9SLCBvciBhIHNjaGVtYSBwYXRoXG4gICAgZm9yIChjb25zdCByZWxhdGlvbk9yUGF0aCBvZiBPYmplY3Qua2V5cyh3aGVyZSkpIHtcbiAgICAgIGNvbnN0IGNvbmRpdGlvbiA9IHdoZXJlW3JlbGF0aW9uT3JQYXRoXVxuICAgICAgbGV0IGNvbmRpdGlvbk9wZXJhdG9yOiAnJGFuZCcgfCAnJG9yJ1xuICAgICAgaWYgKHJlbGF0aW9uT3JQYXRoLnRvTG93ZXJDYXNlKCkgPT09ICdhbmQnKSB7XG4gICAgICAgIGNvbmRpdGlvbk9wZXJhdG9yID0gJyRhbmQnXG4gICAgICB9IGVsc2UgaWYgKHJlbGF0aW9uT3JQYXRoLnRvTG93ZXJDYXNlKCkgPT09ICdvcicpIHtcbiAgICAgICAgY29uZGl0aW9uT3BlcmF0b3IgPSAnJG9yJ1xuICAgICAgfVxuICAgICAgaWYgKEFycmF5LmlzQXJyYXkoY29uZGl0aW9uKSkge1xuICAgICAgICBjb25zdCBidWlsdENvbmRpdGlvbnMgPSBhd2FpdCBidWlsZEFuZE9yQ29uZGl0aW9ucyh7XG4gICAgICAgICAgY29sbGVjdGlvblNsdWcsXG4gICAgICAgICAgZmllbGRzLFxuICAgICAgICAgIGdsb2JhbFNsdWcsXG4gICAgICAgICAgbG9jYWxlLFxuICAgICAgICAgIHBheWxvYWQsXG4gICAgICAgICAgd2hlcmU6IGNvbmRpdGlvbixcbiAgICAgICAgfSlcbiAgICAgICAgaWYgKGJ1aWx0Q29uZGl0aW9ucy5sZW5ndGggPiAwKSByZXN1bHRbY29uZGl0aW9uT3BlcmF0b3JdID0gYnVpbHRDb25kaXRpb25zXG4gICAgICB9IGVsc2Uge1xuICAgICAgICAvLyBJdCdzIGEgcGF0aCAtIGFuZCB0aGVyZSBjYW4gYmUgbXVsdGlwbGUgY29tcGFyaXNvbnMgb24gYSBzaW5nbGUgcGF0aC5cbiAgICAgICAgLy8gRm9yIGV4YW1wbGUgLSB0aXRsZSBsaWtlICd0ZXN0JyBhbmQgdGl0bGUgbm90IGVxdWFsIHRvICd0ZXN0ZXInXG4gICAgICAgIC8vIFNvIHdlIG5lZWQgdG8gbG9vcCBvbiBrZXlzIGFnYWluIGhlcmUgdG8gaGFuZGxlIGVhY2ggb3BlcmF0b3IgaW5kZXBlbmRlbnRseVxuICAgICAgICBjb25zdCBwYXRoT3BlcmF0b3JzID0gd2hlcmVbcmVsYXRpb25PclBhdGhdXG4gICAgICAgIGlmICh0eXBlb2YgcGF0aE9wZXJhdG9ycyA9PT0gJ29iamVjdCcpIHtcbiAgICAgICAgICBmb3IgKGNvbnN0IG9wZXJhdG9yIG9mIE9iamVjdC5rZXlzKHBhdGhPcGVyYXRvcnMpKSB7XG4gICAgICAgICAgICBpZiAodmFsaWRPcGVyYXRvcnMuaW5jbHVkZXMob3BlcmF0b3IgYXMgT3BlcmF0b3IpKSB7XG4gICAgICAgICAgICAgIGNvbnN0IHNlYXJjaFBhcmFtID0gYXdhaXQgYnVpbGRTZWFyY2hQYXJhbSh7XG4gICAgICAgICAgICAgICAgY29sbGVjdGlvblNsdWcsXG4gICAgICAgICAgICAgICAgZmllbGRzLFxuICAgICAgICAgICAgICAgIGdsb2JhbFNsdWcsXG4gICAgICAgICAgICAgICAgaW5jb21pbmdQYXRoOiByZWxhdGlvbk9yUGF0aCxcbiAgICAgICAgICAgICAgICBsb2NhbGUsXG4gICAgICAgICAgICAgICAgb3BlcmF0b3IsXG4gICAgICAgICAgICAgICAgcGF5bG9hZCxcbiAgICAgICAgICAgICAgICB2YWw6IHBhdGhPcGVyYXRvcnNbb3BlcmF0b3JdLFxuICAgICAgICAgICAgICB9KVxuXG4gICAgICAgICAgICAgIGlmIChzZWFyY2hQYXJhbT8udmFsdWUgJiYgc2VhcmNoUGFyYW0/LnBhdGgpIHtcbiAgICAgICAgICAgICAgICByZXN1bHQgPSB7XG4gICAgICAgICAgICAgICAgICAuLi5yZXN1bHQsXG4gICAgICAgICAgICAgICAgICBbc2VhcmNoUGFyYW0ucGF0aF06IHNlYXJjaFBhcmFtLnZhbHVlLFxuICAgICAgICAgICAgICAgIH1cbiAgICAgICAgICAgICAgfSBlbHNlIGlmICh0eXBlb2Ygc2VhcmNoUGFyYW0/LnZhbHVlID09PSAnb2JqZWN0Jykge1xuICAgICAgICAgICAgICAgIHJlc3VsdCA9IGRlZXBtZXJnZShyZXN1bHQsIHNlYXJjaFBhcmFtLnZhbHVlLCB7IGFycmF5TWVyZ2U6IGNvbWJpbmVNZXJnZSB9KVxuICAgICAgICAgICAgICB9XG4gICAgICAgICAgICB9XG4gICAgICAgICAgfVxuICAgICAgICB9XG4gICAgICB9XG4gICAgfVxuICB9XG5cbiAgcmV0dXJuIHJlc3VsdFxufVxuIl0sIm5hbWVzIjpbInBhcnNlUGFyYW1zIiwiY29sbGVjdGlvblNsdWciLCJmaWVsZHMiLCJnbG9iYWxTbHVnIiwibG9jYWxlIiwicGF5bG9hZCIsIndoZXJlIiwicmVzdWx0IiwicmVsYXRpb25PclBhdGgiLCJPYmplY3QiLCJrZXlzIiwiY29uZGl0aW9uIiwiY29uZGl0aW9uT3BlcmF0b3IiLCJ0b0xvd2VyQ2FzZSIsIkFycmF5IiwiaXNBcnJheSIsImJ1aWx0Q29uZGl0aW9ucyIsImJ1aWxkQW5kT3JDb25kaXRpb25zIiwibGVuZ3RoIiwicGF0aE9wZXJhdG9ycyIsIm9wZXJhdG9yIiwidmFsaWRPcGVyYXRvcnMiLCJpbmNsdWRlcyIsInNlYXJjaFBhcmFtIiwiYnVpbGRTZWFyY2hQYXJhbSIsImluY29taW5nUGF0aCIsInZhbCIsInZhbHVlIiwicGF0aCIsImRlZXBtZXJnZSIsImFycmF5TWVyZ2UiLCJjb21iaW5lTWVyZ2UiXSwibWFwcGluZ3MiOiJBQUFBLHVDQUF1QyxHQUN2QyxtQ0FBbUM7Ozs7K0JBYWJBOzs7ZUFBQUE7OztrRUFQQTt1QkFDUzsyQkFDRjtzQ0FFUTttQ0FDSjs7Ozs7O0FBRTFCLGVBQWVBLFlBQVksRUFDaENDLGNBQWMsRUFDZEMsTUFBTSxFQUNOQyxVQUFVLEVBQ1ZDLE1BQU0sRUFDTkMsT0FBTyxFQUNQQyxLQUFLLEVBUU47SUFDQyxJQUFJQyxTQUFTLENBQUM7SUFFZCxJQUFJLE9BQU9ELFVBQVUsVUFBVTtRQUM3Qix1RUFBdUU7UUFDdkUsS0FBSyxNQUFNRSxrQkFBa0JDLE9BQU9DLElBQUksQ0FBQ0osT0FBUTtZQUMvQyxNQUFNSyxZQUFZTCxLQUFLLENBQUNFLGVBQWU7WUFDdkMsSUFBSUk7WUFDSixJQUFJSixlQUFlSyxXQUFXLE9BQU8sT0FBTztnQkFDMUNELG9CQUFvQjtZQUN0QixPQUFPLElBQUlKLGVBQWVLLFdBQVcsT0FBTyxNQUFNO2dCQUNoREQsb0JBQW9CO1lBQ3RCO1lBQ0EsSUFBSUUsTUFBTUMsT0FBTyxDQUFDSixZQUFZO2dCQUM1QixNQUFNSyxrQkFBa0IsTUFBTUMsSUFBQUEsMENBQW9CLEVBQUM7b0JBQ2pEaEI7b0JBQ0FDO29CQUNBQztvQkFDQUM7b0JBQ0FDO29CQUNBQyxPQUFPSztnQkFDVDtnQkFDQSxJQUFJSyxnQkFBZ0JFLE1BQU0sR0FBRyxHQUFHWCxNQUFNLENBQUNLLGtCQUFrQixHQUFHSTtZQUM5RCxPQUFPO2dCQUNMLHdFQUF3RTtnQkFDeEUsa0VBQWtFO2dCQUNsRSw4RUFBOEU7Z0JBQzlFLE1BQU1HLGdCQUFnQmIsS0FBSyxDQUFDRSxlQUFlO2dCQUMzQyxJQUFJLE9BQU9XLGtCQUFrQixVQUFVO29CQUNyQyxLQUFLLE1BQU1DLFlBQVlYLE9BQU9DLElBQUksQ0FBQ1MsZUFBZ0I7d0JBQ2pELElBQUlFLHFCQUFjLENBQUNDLFFBQVEsQ0FBQ0YsV0FBdUI7NEJBQ2pELE1BQU1HLGNBQWMsTUFBTUMsSUFBQUEsbUNBQWdCLEVBQUM7Z0NBQ3pDdkI7Z0NBQ0FDO2dDQUNBQztnQ0FDQXNCLGNBQWNqQjtnQ0FDZEo7Z0NBQ0FnQjtnQ0FDQWY7Z0NBQ0FxQixLQUFLUCxhQUFhLENBQUNDLFNBQVM7NEJBQzlCOzRCQUVBLElBQUlHLGFBQWFJLFNBQVNKLGFBQWFLLE1BQU07Z0NBQzNDckIsU0FBUztvQ0FDUCxHQUFHQSxNQUFNO29DQUNULENBQUNnQixZQUFZSyxJQUFJLENBQUMsRUFBRUwsWUFBWUksS0FBSztnQ0FDdkM7NEJBQ0YsT0FBTyxJQUFJLE9BQU9KLGFBQWFJLFVBQVUsVUFBVTtnQ0FDakRwQixTQUFTc0IsSUFBQUEsa0JBQVMsRUFBQ3RCLFFBQVFnQixZQUFZSSxLQUFLLEVBQUU7b0NBQUVHLFlBQVlDLHVCQUFZO2dDQUFDOzRCQUMzRTt3QkFDRjtvQkFDRjtnQkFDRjtZQUNGO1FBQ0Y7SUFDRjtJQUVBLE9BQU94QjtBQUNUIn0=
@@ -0,0 +1,11 @@
1
+ import type { Field, TabAsField } from 'payload/types';
2
+ type SanitizeQueryValueArgs = {
3
+ field: Field | TabAsField;
4
+ hasCustomID: boolean;
5
+ operator: string;
6
+ path: string;
7
+ val: any;
8
+ };
9
+ export declare const sanitizeQueryValue: ({ field, hasCustomID, operator, path, val, }: SanitizeQueryValueArgs) => unknown;
10
+ export {};
11
+ //# sourceMappingURL=sanitizeQueryValue.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"sanitizeQueryValue.d.ts","sourceRoot":"","sources":["../../src/queries/sanitizeQueryValue.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,KAAK,EAAE,UAAU,EAAE,MAAM,eAAe,CAAA;AAKtD,KAAK,sBAAsB,GAAG;IAC5B,KAAK,EAAE,KAAK,GAAG,UAAU,CAAA;IACzB,WAAW,EAAE,OAAO,CAAA;IACpB,QAAQ,EAAE,MAAM,CAAA;IAChB,IAAI,EAAE,MAAM,CAAA;IACZ,GAAG,EAAE,GAAG,CAAA;CACT,CAAA;AAED,eAAO,MAAM,kBAAkB,iDAM5B,sBAAsB,KAAG,OA+G3B,CAAA"}
@@ -0,0 +1,128 @@
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 _mongoose = /*#__PURE__*/ _interop_require_default(require("mongoose"));
12
+ const _utilities = require("payload/utilities");
13
+ function _interop_require_default(obj) {
14
+ return obj && obj.__esModule ? obj : {
15
+ default: obj
16
+ };
17
+ }
18
+ const sanitizeQueryValue = ({ field, hasCustomID, operator, path, val })=>{
19
+ let formattedValue = val;
20
+ // Disregard invalid _ids
21
+ if (path === '_id' && typeof val === 'string' && val.split(',').length === 1) {
22
+ if (!hasCustomID) {
23
+ const isValid = _mongoose.default.Types.ObjectId.isValid(val);
24
+ if (!isValid) {
25
+ return undefined;
26
+ }
27
+ }
28
+ if (field.type === 'number') {
29
+ const parsedNumber = parseFloat(val);
30
+ if (Number.isNaN(parsedNumber)) {
31
+ return undefined;
32
+ }
33
+ }
34
+ }
35
+ // Cast incoming values as proper searchable types
36
+ if (field.type === 'checkbox' && typeof val === 'string') {
37
+ if (val.toLowerCase() === 'true') formattedValue = true;
38
+ if (val.toLowerCase() === 'false') formattedValue = false;
39
+ }
40
+ if ([
41
+ 'all',
42
+ 'in',
43
+ 'not_in'
44
+ ].includes(operator) && typeof formattedValue === 'string') {
45
+ formattedValue = (0, _utilities.createArrayFromCommaDelineated)(formattedValue);
46
+ if (field.type === 'number') {
47
+ formattedValue = formattedValue.map((arrayVal)=>parseFloat(arrayVal));
48
+ }
49
+ }
50
+ if (field.type === 'number' && typeof formattedValue === 'string') {
51
+ formattedValue = Number(val);
52
+ }
53
+ if (field.type === 'date' && typeof val === 'string') {
54
+ formattedValue = new Date(val);
55
+ if (Number.isNaN(Date.parse(formattedValue))) {
56
+ return undefined;
57
+ }
58
+ }
59
+ if ([
60
+ 'relationship',
61
+ 'upload'
62
+ ].includes(field.type)) {
63
+ if (val === 'null') {
64
+ formattedValue = null;
65
+ }
66
+ if (operator === 'in' && Array.isArray(formattedValue)) {
67
+ formattedValue = formattedValue.reduce((formattedValues, inVal)=>{
68
+ const newValues = [
69
+ inVal
70
+ ];
71
+ if (_mongoose.default.Types.ObjectId.isValid(inVal)) newValues.push(new _mongoose.default.Types.ObjectId(inVal));
72
+ const parsedNumber = parseFloat(inVal);
73
+ if (!Number.isNaN(parsedNumber)) newValues.push(parsedNumber);
74
+ return [
75
+ ...formattedValues,
76
+ ...newValues
77
+ ];
78
+ }, []);
79
+ }
80
+ }
81
+ // Set up specific formatting necessary by operators
82
+ if (operator === 'near') {
83
+ let lng;
84
+ let lat;
85
+ let maxDistance;
86
+ let minDistance;
87
+ if (Array.isArray(formattedValue)) {
88
+ [lng, lat, maxDistance, minDistance] = formattedValue;
89
+ }
90
+ if (typeof formattedValue === 'string') {
91
+ [lng, lat, maxDistance, minDistance] = (0, _utilities.createArrayFromCommaDelineated)(formattedValue);
92
+ }
93
+ if (lng == null || lat == null || maxDistance == null && minDistance == null) {
94
+ formattedValue = undefined;
95
+ } else {
96
+ formattedValue = {
97
+ $geometry: {
98
+ coordinates: [
99
+ parseFloat(lng),
100
+ parseFloat(lat)
101
+ ],
102
+ type: 'Point'
103
+ }
104
+ };
105
+ if (maxDistance) formattedValue.$maxDistance = parseFloat(maxDistance);
106
+ if (minDistance) formattedValue.$minDistance = parseFloat(minDistance);
107
+ }
108
+ }
109
+ if (operator === 'within' || operator === 'intersects') {
110
+ formattedValue = {
111
+ $geometry: formattedValue
112
+ };
113
+ }
114
+ if (path !== '_id' || path === '_id' && hasCustomID && field.type === 'text') {
115
+ if (operator === 'contains') {
116
+ formattedValue = {
117
+ $options: 'i',
118
+ $regex: formattedValue
119
+ };
120
+ }
121
+ }
122
+ if (operator === 'exists') {
123
+ formattedValue = formattedValue === 'true' || formattedValue === true;
124
+ }
125
+ return formattedValue;
126
+ };
127
+
128
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../src/queries/sanitizeQueryValue.ts"],"sourcesContent":["import type { Field, TabAsField } from 'payload/types'\n\nimport mongoose from 'mongoose'\nimport { createArrayFromCommaDelineated } from 'payload/utilities'\n\ntype SanitizeQueryValueArgs = {\n  field: Field | TabAsField\n  hasCustomID: boolean\n  operator: string\n  path: string\n  val: any\n}\n\nexport const sanitizeQueryValue = ({\n  field,\n  hasCustomID,\n  operator,\n  path,\n  val,\n}: SanitizeQueryValueArgs): unknown => {\n  let formattedValue = val\n\n  // Disregard invalid _ids\n  if (path === '_id' && typeof val === 'string' && val.split(',').length === 1) {\n    if (!hasCustomID) {\n      const isValid = mongoose.Types.ObjectId.isValid(val)\n\n      if (!isValid) {\n        return undefined\n      }\n    }\n\n    if (field.type === 'number') {\n      const parsedNumber = parseFloat(val)\n\n      if (Number.isNaN(parsedNumber)) {\n        return undefined\n      }\n    }\n  }\n\n  // Cast incoming values as proper searchable types\n  if (field.type === 'checkbox' && typeof val === 'string') {\n    if (val.toLowerCase() === 'true') formattedValue = true\n    if (val.toLowerCase() === 'false') formattedValue = false\n  }\n\n  if (['all', 'in', 'not_in'].includes(operator) && typeof formattedValue === 'string') {\n    formattedValue = createArrayFromCommaDelineated(formattedValue)\n\n    if (field.type === 'number') {\n      formattedValue = formattedValue.map((arrayVal) => parseFloat(arrayVal))\n    }\n  }\n\n  if (field.type === 'number' && typeof formattedValue === 'string') {\n    formattedValue = Number(val)\n  }\n\n  if (field.type === 'date' && typeof val === 'string') {\n    formattedValue = new Date(val)\n    if (Number.isNaN(Date.parse(formattedValue))) {\n      return undefined\n    }\n  }\n\n  if (['relationship', 'upload'].includes(field.type)) {\n    if (val === 'null') {\n      formattedValue = null\n    }\n\n    if (operator === 'in' && Array.isArray(formattedValue)) {\n      formattedValue = formattedValue.reduce((formattedValues, inVal) => {\n        const newValues = [inVal]\n        if (mongoose.Types.ObjectId.isValid(inVal))\n          newValues.push(new mongoose.Types.ObjectId(inVal))\n\n        const parsedNumber = parseFloat(inVal)\n        if (!Number.isNaN(parsedNumber)) newValues.push(parsedNumber)\n\n        return [...formattedValues, ...newValues]\n      }, [])\n    }\n  }\n\n  // Set up specific formatting necessary by operators\n\n  if (operator === 'near') {\n    let lng\n    let lat\n    let maxDistance\n    let minDistance\n\n    if (Array.isArray(formattedValue)) {\n      ;[lng, lat, maxDistance, minDistance] = formattedValue\n    }\n\n    if (typeof formattedValue === 'string') {\n      ;[lng, lat, maxDistance, minDistance] = createArrayFromCommaDelineated(formattedValue)\n    }\n\n    if (lng == null || lat == null || (maxDistance == null && minDistance == null)) {\n      formattedValue = undefined\n    } else {\n      formattedValue = {\n        $geometry: { coordinates: [parseFloat(lng), parseFloat(lat)], type: 'Point' },\n      }\n\n      if (maxDistance) formattedValue.$maxDistance = parseFloat(maxDistance)\n      if (minDistance) formattedValue.$minDistance = parseFloat(minDistance)\n    }\n  }\n\n  if (operator === 'within' || operator === 'intersects') {\n    formattedValue = {\n      $geometry: formattedValue,\n    }\n  }\n\n  if (path !== '_id' || (path === '_id' && hasCustomID && field.type === 'text')) {\n    if (operator === 'contains') {\n      formattedValue = { $options: 'i', $regex: formattedValue }\n    }\n  }\n\n  if (operator === 'exists') {\n    formattedValue = formattedValue === 'true' || formattedValue === true\n  }\n\n  return formattedValue\n}\n"],"names":["sanitizeQueryValue","field","hasCustomID","operator","path","val","formattedValue","split","length","isValid","mongoose","Types","ObjectId","undefined","type","parsedNumber","parseFloat","Number","isNaN","toLowerCase","includes","createArrayFromCommaDelineated","map","arrayVal","Date","parse","Array","isArray","reduce","formattedValues","inVal","newValues","push","lng","lat","maxDistance","minDistance","$geometry","coordinates","$maxDistance","$minDistance","$options","$regex"],"mappings":"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"}
@@ -0,0 +1,3 @@
1
+ import type { QueryDrafts } from 'payload/database';
2
+ export declare const queryDrafts: QueryDrafts;
3
+ //# sourceMappingURL=queryDrafts.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"queryDrafts.d.ts","sourceRoot":"","sources":["../src/queryDrafts.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,kBAAkB,CAAA;AAWnD,eAAO,MAAM,WAAW,EAAE,WAqEzB,CAAA"}
@@ -0,0 +1,82 @@
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 _buildSortParam = require("./queries/buildSortParam");
13
+ const _sanitizeInternalFields = /*#__PURE__*/ _interop_require_default(require("./utilities/sanitizeInternalFields"));
14
+ const _withSession = require("./withSession");
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, pagination, req = {}, sort: sortArg, where }) {
21
+ const VersionModel = this.versions[collection];
22
+ const collectionConfig = this.payload.collections[collection].config;
23
+ const options = (0, _withSession.withSession)(this, req.transactionID);
24
+ let hasNearConstraint;
25
+ let sort;
26
+ if (where) {
27
+ const constraints = (0, _database.flattenWhereToOperators)(where);
28
+ hasNearConstraint = constraints.some((prop)=>Object.keys(prop).some((key)=>key === 'near'));
29
+ }
30
+ if (!hasNearConstraint) {
31
+ sort = (0, _buildSortParam.buildSortParam)({
32
+ config: this.payload.config,
33
+ fields: collectionConfig.fields,
34
+ locale,
35
+ sort: sortArg || collectionConfig.defaultSort,
36
+ timestamps: true
37
+ });
38
+ }
39
+ const combinedWhere = (0, _database.combineQueries)({
40
+ latest: {
41
+ equals: true
42
+ }
43
+ }, where);
44
+ const versionQuery = await VersionModel.buildQuery({
45
+ locale,
46
+ payload: this.payload,
47
+ where: combinedWhere
48
+ });
49
+ const paginationOptions = {
50
+ forceCountFn: hasNearConstraint,
51
+ lean: true,
52
+ leanWithId: true,
53
+ options,
54
+ page,
55
+ pagination,
56
+ sort,
57
+ useEstimatedCount: hasNearConstraint
58
+ };
59
+ if (limit > 0) {
60
+ paginationOptions.limit = limit;
61
+ // limit must also be set here, it's ignored when pagination is false
62
+ paginationOptions.options.limit = limit;
63
+ }
64
+ const result = await VersionModel.paginate(versionQuery, paginationOptions);
65
+ const docs = JSON.parse(JSON.stringify(result.docs));
66
+ return {
67
+ ...result,
68
+ docs: docs.map((doc)=>{
69
+ // eslint-disable-next-line no-param-reassign
70
+ doc = {
71
+ _id: doc.parent,
72
+ id: doc.parent,
73
+ ...doc.version,
74
+ createdAt: doc.createdAt,
75
+ updatedAt: doc.updatedAt
76
+ };
77
+ return (0, _sanitizeInternalFields.default)(doc);
78
+ })
79
+ };
80
+ };
81
+
82
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uL3NyYy9xdWVyeURyYWZ0cy50cyJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgdHlwZSB7IFBhZ2luYXRlT3B0aW9ucyB9IGZyb20gJ21vbmdvb3NlJ1xuaW1wb3J0IHR5cGUgeyBRdWVyeURyYWZ0cyB9IGZyb20gJ3BheWxvYWQvZGF0YWJhc2UnXG5pbXBvcnQgdHlwZSB7IFBheWxvYWRSZXF1ZXN0IH0gZnJvbSAncGF5bG9hZC90eXBlcydcblxuaW1wb3J0IHsgY29tYmluZVF1ZXJpZXMsIGZsYXR0ZW5XaGVyZVRvT3BlcmF0b3JzIH0gZnJvbSAncGF5bG9hZC9kYXRhYmFzZSdcblxuaW1wb3J0IHR5cGUgeyBNb25nb29zZUFkYXB0ZXIgfSBmcm9tICcuJ1xuXG5pbXBvcnQgeyBidWlsZFNvcnRQYXJhbSB9IGZyb20gJy4vcXVlcmllcy9idWlsZFNvcnRQYXJhbSdcbmltcG9ydCBzYW5pdGl6ZUludGVybmFsRmllbGRzIGZyb20gJy4vdXRpbGl0aWVzL3Nhbml0aXplSW50ZXJuYWxGaWVsZHMnXG5pbXBvcnQgeyB3aXRoU2Vzc2lvbiB9IGZyb20gJy4vd2l0aFNlc3Npb24nXG5cbmV4cG9ydCBjb25zdCBxdWVyeURyYWZ0czogUXVlcnlEcmFmdHMgPSBhc3luYyBmdW5jdGlvbiBxdWVyeURyYWZ0cyhcbiAgdGhpczogTW9uZ29vc2VBZGFwdGVyLFxuICB7IGNvbGxlY3Rpb24sIGxpbWl0LCBsb2NhbGUsIHBhZ2UsIHBhZ2luYXRpb24sIHJlcSA9IHt9IGFzIFBheWxvYWRSZXF1ZXN0LCBzb3J0OiBzb3J0QXJnLCB3aGVyZSB9LFxuKSB7XG4gIGNvbnN0IFZlcnNpb25Nb2RlbCA9IHRoaXMudmVyc2lvbnNbY29sbGVjdGlvbl1cbiAgY29uc3QgY29sbGVjdGlvbkNvbmZpZyA9IHRoaXMucGF5bG9hZC5jb2xsZWN0aW9uc1tjb2xsZWN0aW9uXS5jb25maWdcbiAgY29uc3Qgb3B0aW9ucyA9IHdpdGhTZXNzaW9uKHRoaXMsIHJlcS50cmFuc2FjdGlvbklEKVxuXG4gIGxldCBoYXNOZWFyQ29uc3RyYWludFxuICBsZXQgc29ydFxuXG4gIGlmICh3aGVyZSkge1xuICAgIGNvbnN0IGNvbnN0cmFpbnRzID0gZmxhdHRlbldoZXJlVG9PcGVyYXRvcnMod2hlcmUpXG4gICAgaGFzTmVhckNvbnN0cmFpbnQgPSBjb25zdHJhaW50cy5zb21lKChwcm9wKSA9PiBPYmplY3Qua2V5cyhwcm9wKS5zb21lKChrZXkpID0+IGtleSA9PT0gJ25lYXInKSlcbiAgfVxuXG4gIGlmICghaGFzTmVhckNvbnN0cmFpbnQpIHtcbiAgICBzb3J0ID0gYnVpbGRTb3J0UGFyYW0oe1xuICAgICAgY29uZmlnOiB0aGlzLnBheWxvYWQuY29uZmlnLFxuICAgICAgZmllbGRzOiBjb2xsZWN0aW9uQ29uZmlnLmZpZWxkcyxcbiAgICAgIGxvY2FsZSxcbiAgICAgIHNvcnQ6IHNvcnRBcmcgfHwgY29sbGVjdGlvbkNvbmZpZy5kZWZhdWx0U29ydCxcbiAgICAgIHRpbWVzdGFtcHM6IHRydWUsXG4gICAgfSlcbiAgfVxuXG4gIGNvbnN0IGNvbWJpbmVkV2hlcmUgPSBjb21iaW5lUXVlcmllcyh7IGxhdGVzdDogeyBlcXVhbHM6IHRydWUgfSB9LCB3aGVyZSlcblxuICBjb25zdCB2ZXJzaW9uUXVlcnkgPSBhd2FpdCBWZXJzaW9uTW9kZWwuYnVpbGRRdWVyeSh7XG4gICAgbG9jYWxlLFxuICAgIHBheWxvYWQ6IHRoaXMucGF5bG9hZCxcbiAgICB3aGVyZTogY29tYmluZWRXaGVyZSxcbiAgfSlcblxuICBjb25zdCBwYWdpbmF0aW9uT3B0aW9uczogUGFnaW5hdGVPcHRpb25zID0ge1xuICAgIGZvcmNlQ291bnRGbjogaGFzTmVhckNvbnN0cmFpbnQsXG4gICAgbGVhbjogdHJ1ZSxcbiAgICBsZWFuV2l0aElkOiB0cnVlLFxuICAgIG9wdGlvbnMsXG4gICAgcGFnZSxcbiAgICBwYWdpbmF0aW9uLFxuICAgIHNvcnQsXG4gICAgdXNlRXN0aW1hdGVkQ291bnQ6IGhhc05lYXJDb25zdHJhaW50LFxuICB9XG5cbiAgaWYgKGxpbWl0ID4gMCkge1xuICAgIHBhZ2luYXRpb25PcHRpb25zLmxpbWl0ID0gbGltaXRcbiAgICAvLyBsaW1pdCBtdXN0IGFsc28gYmUgc2V0IGhlcmUsIGl0J3MgaWdub3JlZCB3aGVuIHBhZ2luYXRpb24gaXMgZmFsc2VcbiAgICBwYWdpbmF0aW9uT3B0aW9ucy5vcHRpb25zLmxpbWl0ID0gbGltaXRcbiAgfVxuXG4gIGNvbnN0IHJlc3VsdCA9IGF3YWl0IFZlcnNpb25Nb2RlbC5wYWdpbmF0ZSh2ZXJzaW9uUXVlcnksIHBhZ2luYXRpb25PcHRpb25zKVxuICBjb25zdCBkb2NzID0gSlNPTi5wYXJzZShKU09OLnN0cmluZ2lmeShyZXN1bHQuZG9jcykpXG5cbiAgcmV0dXJuIHtcbiAgICAuLi5yZXN1bHQsXG4gICAgZG9jczogZG9jcy5tYXAoKGRvYykgPT4ge1xuICAgICAgLy8gZXNsaW50LWRpc2FibGUtbmV4dC1saW5lIG5vLXBhcmFtLXJlYXNzaWduXG4gICAgICBkb2MgPSB7XG4gICAgICAgIF9pZDogZG9jLnBhcmVudCxcbiAgICAgICAgaWQ6IGRvYy5wYXJlbnQsXG4gICAgICAgIC4uLmRvYy52ZXJzaW9uLFxuICAgICAgICBjcmVhdGVkQXQ6IGRvYy5jcmVhdGVkQXQsXG4gICAgICAgIHVwZGF0ZWRBdDogZG9jLnVwZGF0ZWRBdCxcbiAgICAgIH1cblxuICAgICAgcmV0dXJuIHNhbml0aXplSW50ZXJuYWxGaWVsZHMoZG9jKVxuICAgIH0pLFxuICB9XG59XG4iXSwibmFtZXMiOlsicXVlcnlEcmFmdHMiLCJjb2xsZWN0aW9uIiwibGltaXQiLCJsb2NhbGUiLCJwYWdlIiwicGFnaW5hdGlvbiIsInJlcSIsInNvcnQiLCJzb3J0QXJnIiwid2hlcmUiLCJWZXJzaW9uTW9kZWwiLCJ2ZXJzaW9ucyIsImNvbGxlY3Rpb25Db25maWciLCJwYXlsb2FkIiwiY29sbGVjdGlvbnMiLCJjb25maWciLCJvcHRpb25zIiwid2l0aFNlc3Npb24iLCJ0cmFuc2FjdGlvbklEIiwiaGFzTmVhckNvbnN0cmFpbnQiLCJjb25zdHJhaW50cyIsImZsYXR0ZW5XaGVyZVRvT3BlcmF0b3JzIiwic29tZSIsInByb3AiLCJPYmplY3QiLCJrZXlzIiwia2V5IiwiYnVpbGRTb3J0UGFyYW0iLCJmaWVsZHMiLCJkZWZhdWx0U29ydCIsInRpbWVzdGFtcHMiLCJjb21iaW5lZFdoZXJlIiwiY29tYmluZVF1ZXJpZXMiLCJsYXRlc3QiLCJlcXVhbHMiLCJ2ZXJzaW9uUXVlcnkiLCJidWlsZFF1ZXJ5IiwicGFnaW5hdGlvbk9wdGlvbnMiLCJmb3JjZUNvdW50Rm4iLCJsZWFuIiwibGVhbldpdGhJZCIsInVzZUVzdGltYXRlZENvdW50IiwicmVzdWx0IiwicGFnaW5hdGUiLCJkb2NzIiwiSlNPTiIsInBhcnNlIiwic3RyaW5naWZ5IiwibWFwIiwiZG9jIiwiX2lkIiwicGFyZW50IiwiaWQiLCJ2ZXJzaW9uIiwiY3JlYXRlZEF0IiwidXBkYXRlZEF0Iiwic2FuaXRpemVJbnRlcm5hbEZpZWxkcyJdLCJtYXBwaW5ncyI6Ijs7OzsrQkFZYUE7OztlQUFBQTs7OzBCQVIyQztnQ0FJekI7K0VBQ0k7NkJBQ1A7Ozs7OztBQUVyQixNQUFNQSxjQUEyQixlQUFlQSxZQUVyRCxFQUFFQyxVQUFVLEVBQUVDLEtBQUssRUFBRUMsTUFBTSxFQUFFQyxJQUFJLEVBQUVDLFVBQVUsRUFBRUMsTUFBTSxDQUFDLENBQW1CLEVBQUVDLE1BQU1DLE9BQU8sRUFBRUMsS0FBSyxFQUFFO0lBRWpHLE1BQU1DLGVBQWUsSUFBSSxDQUFDQyxRQUFRLENBQUNWLFdBQVc7SUFDOUMsTUFBTVcsbUJBQW1CLElBQUksQ0FBQ0MsT0FBTyxDQUFDQyxXQUFXLENBQUNiLFdBQVcsQ0FBQ2MsTUFBTTtJQUNwRSxNQUFNQyxVQUFVQyxJQUFBQSx3QkFBVyxFQUFDLElBQUksRUFBRVgsSUFBSVksYUFBYTtJQUVuRCxJQUFJQztJQUNKLElBQUlaO0lBRUosSUFBSUUsT0FBTztRQUNULE1BQU1XLGNBQWNDLElBQUFBLGlDQUF1QixFQUFDWjtRQUM1Q1Usb0JBQW9CQyxZQUFZRSxJQUFJLENBQUMsQ0FBQ0MsT0FBU0MsT0FBT0MsSUFBSSxDQUFDRixNQUFNRCxJQUFJLENBQUMsQ0FBQ0ksTUFBUUEsUUFBUTtJQUN6RjtJQUVBLElBQUksQ0FBQ1AsbUJBQW1CO1FBQ3RCWixPQUFPb0IsSUFBQUEsOEJBQWMsRUFBQztZQUNwQlosUUFBUSxJQUFJLENBQUNGLE9BQU8sQ0FBQ0UsTUFBTTtZQUMzQmEsUUFBUWhCLGlCQUFpQmdCLE1BQU07WUFDL0J6QjtZQUNBSSxNQUFNQyxXQUFXSSxpQkFBaUJpQixXQUFXO1lBQzdDQyxZQUFZO1FBQ2Q7SUFDRjtJQUVBLE1BQU1DLGdCQUFnQkMsSUFBQUEsd0JBQWMsRUFBQztRQUFFQyxRQUFRO1lBQUVDLFFBQVE7UUFBSztJQUFFLEdBQUd6QjtJQUVuRSxNQUFNMEIsZUFBZSxNQUFNekIsYUFBYTBCLFVBQVUsQ0FBQztRQUNqRGpDO1FBQ0FVLFNBQVMsSUFBSSxDQUFDQSxPQUFPO1FBQ3JCSixPQUFPc0I7SUFDVDtJQUVBLE1BQU1NLG9CQUFxQztRQUN6Q0MsY0FBY25CO1FBQ2RvQixNQUFNO1FBQ05DLFlBQVk7UUFDWnhCO1FBQ0FaO1FBQ0FDO1FBQ0FFO1FBQ0FrQyxtQkFBbUJ0QjtJQUNyQjtJQUVBLElBQUlqQixRQUFRLEdBQUc7UUFDYm1DLGtCQUFrQm5DLEtBQUssR0FBR0E7UUFDMUIscUVBQXFFO1FBQ3JFbUMsa0JBQWtCckIsT0FBTyxDQUFDZCxLQUFLLEdBQUdBO0lBQ3BDO0lBRUEsTUFBTXdDLFNBQVMsTUFBTWhDLGFBQWFpQyxRQUFRLENBQUNSLGNBQWNFO0lBQ3pELE1BQU1PLE9BQU9DLEtBQUtDLEtBQUssQ0FBQ0QsS0FBS0UsU0FBUyxDQUFDTCxPQUFPRSxJQUFJO0lBRWxELE9BQU87UUFDTCxHQUFHRixNQUFNO1FBQ1RFLE1BQU1BLEtBQUtJLEdBQUcsQ0FBQyxDQUFDQztZQUNkLDZDQUE2QztZQUM3Q0EsTUFBTTtnQkFDSkMsS0FBS0QsSUFBSUUsTUFBTTtnQkFDZkMsSUFBSUgsSUFBSUUsTUFBTTtnQkFDZCxHQUFHRixJQUFJSSxPQUFPO2dCQUNkQyxXQUFXTCxJQUFJSyxTQUFTO2dCQUN4QkMsV0FBV04sSUFBSU0sU0FBUztZQUMxQjtZQUVBLE9BQU9DLElBQUFBLCtCQUFzQixFQUFDUDtRQUNoQztJQUNGO0FBQ0YifQ==
@@ -0,0 +1,8 @@
1
+ export declare const email = "test@test.com";
2
+ export declare const password = "test123";
3
+ export declare const connection: {
4
+ name: string;
5
+ port: number;
6
+ url: string;
7
+ };
8
+ //# sourceMappingURL=testCredentials.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"testCredentials.d.ts","sourceRoot":"","sources":["../src/testCredentials.ts"],"names":[],"mappings":"AAAA,eAAO,MAAM,KAAK,kBAAkB,CAAA;AACpC,eAAO,MAAM,QAAQ,YAAY,CAAA;AACjC,eAAO,MAAM,UAAU;;;;CAItB,CAAA"}