@payloadcms/db-mongodb 1.5.0 → 1.5.2

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.
@@ -0,0 +1,3 @@
1
+ import type { Count } from 'payload/database';
2
+ export declare const count: Count;
3
+ //# sourceMappingURL=count.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"count.d.ts","sourceRoot":"","sources":["../src/count.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,KAAK,EAAE,MAAM,kBAAkB,CAAA;AAS7C,eAAO,MAAM,KAAK,EAAE,KAsCnB,CAAA"}
package/dist/count.js ADDED
@@ -0,0 +1,43 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", {
3
+ value: true
4
+ });
5
+ Object.defineProperty(exports, "count", {
6
+ enumerable: true,
7
+ get: function() {
8
+ return count;
9
+ }
10
+ });
11
+ const _database = require("payload/database");
12
+ const _withSession = require("./withSession");
13
+ const count = async function count({ collection, locale, req = {}, where }) {
14
+ const Model = this.collections[collection];
15
+ const options = (0, _withSession.withSession)(this, req.transactionID);
16
+ let hasNearConstraint = false;
17
+ if (where) {
18
+ const constraints = (0, _database.flattenWhereToOperators)(where);
19
+ hasNearConstraint = constraints.some((prop)=>Object.keys(prop).some((key)=>key === 'near'));
20
+ }
21
+ const query = await Model.buildQuery({
22
+ locale,
23
+ payload: this.payload,
24
+ where
25
+ });
26
+ // useEstimatedCount is faster, but not accurate, as it ignores any filters. It is thus set to true if there are no filters.
27
+ const useEstimatedCount = hasNearConstraint || !query || Object.keys(query).length === 0;
28
+ if (!useEstimatedCount && Object.keys(query).length === 0 && this.disableIndexHints !== true) {
29
+ // Improve the performance of the countDocuments query which is used if useEstimatedCount is set to false by adding
30
+ // a hint. By default, if no hint is provided, MongoDB does not use an indexed field to count the returned documents,
31
+ // which makes queries very slow. This only happens when no query (filter) is provided. If one is provided, it uses
32
+ // the correct indexed field
33
+ options.hint = {
34
+ _id: 1
35
+ };
36
+ }
37
+ const result = await Model.countDocuments(query, options);
38
+ return {
39
+ totalDocs: result
40
+ };
41
+ };
42
+
43
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uL3NyYy9jb3VudC50cyJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgdHlwZSB7IFF1ZXJ5T3B0aW9ucyB9IGZyb20gJ21vbmdvb3NlJ1xuaW1wb3J0IHR5cGUgeyBDb3VudCB9IGZyb20gJ3BheWxvYWQvZGF0YWJhc2UnXG5pbXBvcnQgdHlwZSB7IFBheWxvYWRSZXF1ZXN0IH0gZnJvbSAncGF5bG9hZC90eXBlcydcblxuaW1wb3J0IHsgZmxhdHRlbldoZXJlVG9PcGVyYXRvcnMgfSBmcm9tICdwYXlsb2FkL2RhdGFiYXNlJ1xuXG5pbXBvcnQgdHlwZSB7IE1vbmdvb3NlQWRhcHRlciB9IGZyb20gJy4nXG5cbmltcG9ydCB7IHdpdGhTZXNzaW9uIH0gZnJvbSAnLi93aXRoU2Vzc2lvbidcblxuZXhwb3J0IGNvbnN0IGNvdW50OiBDb3VudCA9IGFzeW5jIGZ1bmN0aW9uIGNvdW50KFxuICB0aGlzOiBNb25nb29zZUFkYXB0ZXIsXG4gIHsgY29sbGVjdGlvbiwgbG9jYWxlLCByZXEgPSB7fSBhcyBQYXlsb2FkUmVxdWVzdCwgd2hlcmUgfSxcbikge1xuICBjb25zdCBNb2RlbCA9IHRoaXMuY29sbGVjdGlvbnNbY29sbGVjdGlvbl1cbiAgY29uc3Qgb3B0aW9uczogUXVlcnlPcHRpb25zID0gd2l0aFNlc3Npb24odGhpcywgcmVxLnRyYW5zYWN0aW9uSUQpXG5cbiAgbGV0IGhhc05lYXJDb25zdHJhaW50ID0gZmFsc2VcblxuICBpZiAod2hlcmUpIHtcbiAgICBjb25zdCBjb25zdHJhaW50cyA9IGZsYXR0ZW5XaGVyZVRvT3BlcmF0b3JzKHdoZXJlKVxuICAgIGhhc05lYXJDb25zdHJhaW50ID0gY29uc3RyYWludHMuc29tZSgocHJvcCkgPT4gT2JqZWN0LmtleXMocHJvcCkuc29tZSgoa2V5KSA9PiBrZXkgPT09ICduZWFyJykpXG4gIH1cblxuICBjb25zdCBxdWVyeSA9IGF3YWl0IE1vZGVsLmJ1aWxkUXVlcnkoe1xuICAgIGxvY2FsZSxcbiAgICBwYXlsb2FkOiB0aGlzLnBheWxvYWQsXG4gICAgd2hlcmUsXG4gIH0pXG5cbiAgLy8gdXNlRXN0aW1hdGVkQ291bnQgaXMgZmFzdGVyLCBidXQgbm90IGFjY3VyYXRlLCBhcyBpdCBpZ25vcmVzIGFueSBmaWx0ZXJzLiBJdCBpcyB0aHVzIHNldCB0byB0cnVlIGlmIHRoZXJlIGFyZSBubyBmaWx0ZXJzLlxuICBjb25zdCB1c2VFc3RpbWF0ZWRDb3VudCA9IGhhc05lYXJDb25zdHJhaW50IHx8ICFxdWVyeSB8fCBPYmplY3Qua2V5cyhxdWVyeSkubGVuZ3RoID09PSAwXG5cbiAgaWYgKCF1c2VFc3RpbWF0ZWRDb3VudCAmJiBPYmplY3Qua2V5cyhxdWVyeSkubGVuZ3RoID09PSAwICYmIHRoaXMuZGlzYWJsZUluZGV4SGludHMgIT09IHRydWUpIHtcbiAgICAvLyBJbXByb3ZlIHRoZSBwZXJmb3JtYW5jZSBvZiB0aGUgY291bnREb2N1bWVudHMgcXVlcnkgd2hpY2ggaXMgdXNlZCBpZiB1c2VFc3RpbWF0ZWRDb3VudCBpcyBzZXQgdG8gZmFsc2UgYnkgYWRkaW5nXG4gICAgLy8gYSBoaW50LiBCeSBkZWZhdWx0LCBpZiBubyBoaW50IGlzIHByb3ZpZGVkLCBNb25nb0RCIGRvZXMgbm90IHVzZSBhbiBpbmRleGVkIGZpZWxkIHRvIGNvdW50IHRoZSByZXR1cm5lZCBkb2N1bWVudHMsXG4gICAgLy8gd2hpY2ggbWFrZXMgcXVlcmllcyB2ZXJ5IHNsb3cuIFRoaXMgb25seSBoYXBwZW5zIHdoZW4gbm8gcXVlcnkgKGZpbHRlcikgaXMgcHJvdmlkZWQuIElmIG9uZSBpcyBwcm92aWRlZCwgaXQgdXNlc1xuICAgIC8vIHRoZSBjb3JyZWN0IGluZGV4ZWQgZmllbGRcbiAgICBvcHRpb25zLmhpbnQgPSB7XG4gICAgICBfaWQ6IDEsXG4gICAgfVxuICB9XG5cbiAgY29uc3QgcmVzdWx0ID0gYXdhaXQgTW9kZWwuY291bnREb2N1bWVudHMocXVlcnksIG9wdGlvbnMpXG5cbiAgcmV0dXJuIHtcbiAgICB0b3RhbERvY3M6IHJlc3VsdCxcbiAgfVxufVxuIl0sIm5hbWVzIjpbImNvdW50IiwiY29sbGVjdGlvbiIsImxvY2FsZSIsInJlcSIsIndoZXJlIiwiTW9kZWwiLCJjb2xsZWN0aW9ucyIsIm9wdGlvbnMiLCJ3aXRoU2Vzc2lvbiIsInRyYW5zYWN0aW9uSUQiLCJoYXNOZWFyQ29uc3RyYWludCIsImNvbnN0cmFpbnRzIiwiZmxhdHRlbldoZXJlVG9PcGVyYXRvcnMiLCJzb21lIiwicHJvcCIsIk9iamVjdCIsImtleXMiLCJrZXkiLCJxdWVyeSIsImJ1aWxkUXVlcnkiLCJwYXlsb2FkIiwidXNlRXN0aW1hdGVkQ291bnQiLCJsZW5ndGgiLCJkaXNhYmxlSW5kZXhIaW50cyIsImhpbnQiLCJfaWQiLCJyZXN1bHQiLCJjb3VudERvY3VtZW50cyIsInRvdGFsRG9jcyJdLCJyYW5nZU1hcHBpbmdzIjoiOzs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7OyIsIm1hcHBpbmdzIjoiOzs7OytCQVVhQTs7O2VBQUFBOzs7MEJBTjJCOzZCQUlaO0FBRXJCLE1BQU1BLFFBQWUsZUFBZUEsTUFFekMsRUFBRUMsVUFBVSxFQUFFQyxNQUFNLEVBQUVDLE1BQU0sQ0FBQyxDQUFtQixFQUFFQyxLQUFLLEVBQUU7SUFFekQsTUFBTUMsUUFBUSxJQUFJLENBQUNDLFdBQVcsQ0FBQ0wsV0FBVztJQUMxQyxNQUFNTSxVQUF3QkMsSUFBQUEsd0JBQVcsRUFBQyxJQUFJLEVBQUVMLElBQUlNLGFBQWE7SUFFakUsSUFBSUMsb0JBQW9CO0lBRXhCLElBQUlOLE9BQU87UUFDVCxNQUFNTyxjQUFjQyxJQUFBQSxpQ0FBdUIsRUFBQ1I7UUFDNUNNLG9CQUFvQkMsWUFBWUUsSUFBSSxDQUFDLENBQUNDLE9BQVNDLE9BQU9DLElBQUksQ0FBQ0YsTUFBTUQsSUFBSSxDQUFDLENBQUNJLE1BQVFBLFFBQVE7SUFDekY7SUFFQSxNQUFNQyxRQUFRLE1BQU1iLE1BQU1jLFVBQVUsQ0FBQztRQUNuQ2pCO1FBQ0FrQixTQUFTLElBQUksQ0FBQ0EsT0FBTztRQUNyQmhCO0lBQ0Y7SUFFQSw0SEFBNEg7SUFDNUgsTUFBTWlCLG9CQUFvQlgscUJBQXFCLENBQUNRLFNBQVNILE9BQU9DLElBQUksQ0FBQ0UsT0FBT0ksTUFBTSxLQUFLO0lBRXZGLElBQUksQ0FBQ0QscUJBQXFCTixPQUFPQyxJQUFJLENBQUNFLE9BQU9JLE1BQU0sS0FBSyxLQUFLLElBQUksQ0FBQ0MsaUJBQWlCLEtBQUssTUFBTTtRQUM1RixtSEFBbUg7UUFDbkgscUhBQXFIO1FBQ3JILG1IQUFtSDtRQUNuSCw0QkFBNEI7UUFDNUJoQixRQUFRaUIsSUFBSSxHQUFHO1lBQ2JDLEtBQUs7UUFDUDtJQUNGO0lBRUEsTUFBTUMsU0FBUyxNQUFNckIsTUFBTXNCLGNBQWMsQ0FBQ1QsT0FBT1g7SUFFakQsT0FBTztRQUNMcUIsV0FBV0Y7SUFDYjtBQUNGIn0=
@@ -1 +1 @@
1
- {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,kBAAkB,EAAE,MAAM,SAAS,CAAA;AACjD,OAAO,KAAK,EAAE,aAAa,EAAE,cAAc,EAAE,UAAU,EAAE,MAAM,UAAU,CAAA;AACzE,OAAO,KAAK,EAAE,OAAO,EAAE,MAAM,SAAS,CAAA;AACtC,OAAO,KAAK,EAAE,mBAAmB,EAAE,MAAM,kBAAkB,CAAA;AAO3D,OAAO,KAAK,EAAE,eAAe,EAAE,WAAW,EAAE,MAAM,SAAS,CAAA;AA4B3D,YAAY,EAAE,eAAe,EAAE,aAAa,EAAE,MAAM,SAAS,CAAA;AAE7D,MAAM,WAAW,IAAI;IACnB,uFAAuF;IACvF,iBAAiB,CAAC,EAAE,OAAO,CAAA;IAC3B,kCAAkC;IAClC,cAAc,CAAC,EAAE,cAAc,GAAG;QAChC,4FAA4F;QAC5F,QAAQ,CAAC,EAAE,OAAO,CAAA;KACnB,CAAA;IACD,gOAAgO;IAChO,iBAAiB,CAAC,EAAE,OAAO,CAAA;IAC3B,YAAY,CAAC,EAAE,MAAM,CAAA;IACrB,kBAAkB,CAAC,EAAE,kBAAkB,GAAG,KAAK,CAAA;IAC/C,qFAAqF;IACrF,GAAG,EAAE,KAAK,GAAG,MAAM,CAAA;CACpB;AAED,MAAM,MAAM,eAAe,GAAG,mBAAmB,GAC/C,IAAI,GAAG;IACL,WAAW,EAAE;QACX,CAAC,IAAI,EAAE,MAAM,GAAG,eAAe,CAAA;KAChC,CAAA;IACD,UAAU,EAAE,UAAU,CAAA;IACtB,OAAO,EAAE,WAAW,CAAA;IACpB,iBAAiB,EAAE,GAAG,CAAA;IACtB,QAAQ,EAAE,MAAM,CAAC,MAAM,GAAG,MAAM,EAAE,aAAa,CAAC,CAAA;IAChD,QAAQ,EAAE;QACR,CAAC,IAAI,EAAE,MAAM,GAAG,eAAe,CAAA;KAChC,CAAA;CACF,CAAA;AAEH,KAAK,qBAAqB,GAAG,CAAC,IAAI,EAAE;IAAE,OAAO,EAAE,OAAO,CAAA;CAAE,KAAK,eAAe,CAAA;AAE5E,OAAO,QAAQ,SAAS,CAAC;IACvB,UAAiB,eACf,SAAQ,IAAI,CAAC,mBAAmB,EAAE,UAAU,CAAC,EAC3C,IAAI,CAAC,IAAI,EAAE,cAAc,CAAC;QAC5B,WAAW,EAAE;YACX,CAAC,IAAI,EAAE,MAAM,GAAG,eAAe,CAAA;SAChC,CAAA;QACD,UAAU,EAAE,UAAU,CAAA;QACtB,OAAO,EAAE,WAAW,CAAA;QACpB,iBAAiB,EAAE,GAAG,CAAA;QACtB,QAAQ,EAAE,MAAM,CAAC,MAAM,GAAG,MAAM,EAAE,aAAa,CAAC,CAAA;QAChD,kBAAkB,EAAE,kBAAkB,CAAA;QACtC,QAAQ,EAAE;YACR,CAAC,IAAI,EAAE,MAAM,GAAG,eAAe,CAAA;SAChC,CAAA;KACF;CACF;AAED,wBAAgB,eAAe,CAAC,EAC9B,iBAAwB,EACxB,cAAc,EACd,iBAAyB,EACzB,YAAY,EAAE,eAAe,EAC7B,kBAAuB,EACvB,GAAG,GACJ,EAAE,IAAI,GAAG,qBAAqB,CAsD9B"}
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,kBAAkB,EAAE,MAAM,SAAS,CAAA;AACjD,OAAO,KAAK,EAAE,aAAa,EAAE,cAAc,EAAE,UAAU,EAAE,MAAM,UAAU,CAAA;AACzE,OAAO,KAAK,EAAE,OAAO,EAAE,MAAM,SAAS,CAAA;AACtC,OAAO,KAAK,EAAE,mBAAmB,EAAE,MAAM,kBAAkB,CAAA;AAO3D,OAAO,KAAK,EAAE,eAAe,EAAE,WAAW,EAAE,MAAM,SAAS,CAAA;AA6B3D,YAAY,EAAE,eAAe,EAAE,aAAa,EAAE,MAAM,SAAS,CAAA;AAE7D,MAAM,WAAW,IAAI;IACnB,uFAAuF;IACvF,iBAAiB,CAAC,EAAE,OAAO,CAAA;IAC3B,kCAAkC;IAClC,cAAc,CAAC,EAAE,cAAc,GAAG;QAChC,4FAA4F;QAC5F,QAAQ,CAAC,EAAE,OAAO,CAAA;KACnB,CAAA;IACD,gOAAgO;IAChO,iBAAiB,CAAC,EAAE,OAAO,CAAA;IAC3B,YAAY,CAAC,EAAE,MAAM,CAAA;IACrB,kBAAkB,CAAC,EAAE,kBAAkB,GAAG,KAAK,CAAA;IAC/C,qFAAqF;IACrF,GAAG,EAAE,KAAK,GAAG,MAAM,CAAA;CACpB;AAED,MAAM,MAAM,eAAe,GAAG,mBAAmB,GAC/C,IAAI,GAAG;IACL,WAAW,EAAE;QACX,CAAC,IAAI,EAAE,MAAM,GAAG,eAAe,CAAA;KAChC,CAAA;IACD,UAAU,EAAE,UAAU,CAAA;IACtB,OAAO,EAAE,WAAW,CAAA;IACpB,iBAAiB,EAAE,GAAG,CAAA;IACtB,QAAQ,EAAE,MAAM,CAAC,MAAM,GAAG,MAAM,EAAE,aAAa,CAAC,CAAA;IAChD,QAAQ,EAAE;QACR,CAAC,IAAI,EAAE,MAAM,GAAG,eAAe,CAAA;KAChC,CAAA;CACF,CAAA;AAEH,KAAK,qBAAqB,GAAG,CAAC,IAAI,EAAE;IAAE,OAAO,EAAE,OAAO,CAAA;CAAE,KAAK,eAAe,CAAA;AAE5E,OAAO,QAAQ,SAAS,CAAC;IACvB,UAAiB,eACf,SAAQ,IAAI,CAAC,mBAAmB,EAAE,UAAU,CAAC,EAC3C,IAAI,CAAC,IAAI,EAAE,cAAc,CAAC;QAC5B,WAAW,EAAE;YACX,CAAC,IAAI,EAAE,MAAM,GAAG,eAAe,CAAA;SAChC,CAAA;QACD,UAAU,EAAE,UAAU,CAAA;QACtB,OAAO,EAAE,WAAW,CAAA;QACpB,iBAAiB,EAAE,GAAG,CAAA;QACtB,QAAQ,EAAE,MAAM,CAAC,MAAM,GAAG,MAAM,EAAE,aAAa,CAAC,CAAA;QAChD,kBAAkB,EAAE,kBAAkB,CAAA;QACtC,QAAQ,EAAE;YACR,CAAC,IAAI,EAAE,MAAM,GAAG,eAAe,CAAA;SAChC,CAAA;KACF;CACF;AAED,wBAAgB,eAAe,CAAC,EAC9B,iBAAwB,EACxB,cAAc,EACd,iBAAyB,EACzB,YAAY,EAAE,eAAe,EAC7B,kBAAuB,EACvB,GAAG,GACJ,EAAE,IAAI,GAAG,qBAAqB,CAsD9B"}
package/dist/index.js CHANGED
@@ -13,6 +13,7 @@ const _mongoose = /*#__PURE__*/ _interop_require_default(require("mongoose"));
13
13
  const _path = /*#__PURE__*/ _interop_require_default(require("path"));
14
14
  const _database = require("payload/database");
15
15
  const _connect = require("./connect");
16
+ const _count = require("./count");
16
17
  const _create = require("./create");
17
18
  const _createGlobal = require("./createGlobal");
18
19
  const _createGlobalVersion = require("./createGlobalVersion");
@@ -53,6 +54,7 @@ function mongooseAdapter({ autoPluralization = true, connectOptions, disableInde
53
54
  collections: {},
54
55
  connectOptions: connectOptions || {},
55
56
  connection: undefined,
57
+ count: _count.count,
56
58
  disableIndexHints,
57
59
  globals: undefined,
58
60
  mongoMemoryServer: undefined,
@@ -126,4 +128,4 @@ function mongooseAdapter({ autoPluralization = true, connectOptions, disableInde
126
128
  return srcDir;
127
129
  }
128
130
 
129
- //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../src/index.ts"],"sourcesContent":["import type { TransactionOptions } from 'mongodb'\nimport type { ClientSession, ConnectOptions, Connection } from 'mongoose'\nimport type { Payload } from 'payload'\nimport type { BaseDatabaseAdapter } from 'payload/database'\n\nimport fs from 'fs'\nimport mongoose from 'mongoose'\nimport path from 'path'\nimport { createDatabaseAdapter } from 'payload/database'\n\nimport type { CollectionModel, GlobalModel } from './types'\n\nimport { connect } from './connect'\nimport { create } from './create'\nimport { createGlobal } from './createGlobal'\nimport { createGlobalVersion } from './createGlobalVersion'\nimport { createMigration } from './createMigration'\nimport { createVersion } from './createVersion'\nimport { deleteMany } from './deleteMany'\nimport { deleteOne } from './deleteOne'\nimport { deleteVersions } from './deleteVersions'\nimport { destroy } from './destroy'\nimport { find } from './find'\nimport { findGlobal } from './findGlobal'\nimport { findGlobalVersions } from './findGlobalVersions'\nimport { findOne } from './findOne'\nimport { findVersions } from './findVersions'\nimport { init } from './init'\nimport { migrateFresh } from './migrateFresh'\nimport { queryDrafts } from './queryDrafts'\nimport { beginTransaction } from './transactions/beginTransaction'\nimport { commitTransaction } from './transactions/commitTransaction'\nimport { rollbackTransaction } from './transactions/rollbackTransaction'\nimport { updateGlobal } from './updateGlobal'\nimport { updateGlobalVersion } from './updateGlobalVersion'\nimport { updateOne } from './updateOne'\nimport { updateVersion } from './updateVersion'\n\nexport type { MigrateDownArgs, MigrateUpArgs } from './types'\n\nexport interface Args {\n  /** Set to false to disable auto-pluralization of collection names, Defaults to true */\n  autoPluralization?: boolean\n  /** Extra configuration options */\n  connectOptions?: ConnectOptions & {\n    /** Set false to disable $facet aggregation in non-supporting databases, Defaults to true */\n    useFacet?: boolean\n  }\n  /** Set to true to disable hinting to MongoDB to use 'id' as index. This is currently done when counting documents for pagination. Disabling this optimization might fix some problems with AWS DocumentDB. Defaults to false */\n  disableIndexHints?: boolean\n  migrationDir?: string\n  transactionOptions?: TransactionOptions | false\n  /** The URL to connect to MongoDB or false to start payload and prevent connecting */\n  url: false | string\n}\n\nexport type MongooseAdapter = BaseDatabaseAdapter &\n  Args & {\n    collections: {\n      [slug: string]: CollectionModel\n    }\n    connection: Connection\n    globals: GlobalModel\n    mongoMemoryServer: any\n    sessions: Record<number | string, ClientSession>\n    versions: {\n      [slug: string]: CollectionModel\n    }\n  }\n\ntype MongooseAdapterResult = (args: { payload: Payload }) => MongooseAdapter\n\ndeclare module 'payload' {\n  export interface DatabaseAdapter\n    extends Omit<BaseDatabaseAdapter, 'sessions'>,\n      Omit<Args, 'migrationDir'> {\n    collections: {\n      [slug: string]: CollectionModel\n    }\n    connection: Connection\n    globals: GlobalModel\n    mongoMemoryServer: any\n    sessions: Record<number | string, ClientSession>\n    transactionOptions: TransactionOptions\n    versions: {\n      [slug: string]: CollectionModel\n    }\n  }\n}\n\nexport function mongooseAdapter({\n  autoPluralization = true,\n  connectOptions,\n  disableIndexHints = false,\n  migrationDir: migrationDirArg,\n  transactionOptions = {},\n  url,\n}: Args): MongooseAdapterResult {\n  function adapter({ payload }: { payload: Payload }) {\n    const migrationDir = findMigrationDir(migrationDirArg)\n    mongoose.set('strictQuery', false)\n\n    return createDatabaseAdapter<MongooseAdapter>({\n      name: 'mongoose',\n\n      // Mongoose-specific\n      autoPluralization,\n      collections: {},\n      connectOptions: connectOptions || {},\n      connection: undefined,\n      disableIndexHints,\n      globals: undefined,\n      mongoMemoryServer: undefined,\n      sessions: {},\n      transactionOptions: transactionOptions === false ? undefined : transactionOptions,\n      url,\n      versions: {},\n\n      // DatabaseAdapter\n      beginTransaction: transactionOptions ? beginTransaction : undefined,\n      commitTransaction,\n      connect,\n      create,\n      createGlobal,\n      createGlobalVersion,\n      createMigration,\n      createVersion,\n      defaultIDType: 'text',\n      deleteMany,\n      deleteOne,\n      deleteVersions,\n      destroy,\n      find,\n      findGlobal,\n      findGlobalVersions,\n      findOne,\n      findVersions,\n      init,\n      migrateFresh,\n      migrationDir,\n      payload,\n      queryDrafts,\n      rollbackTransaction,\n      updateGlobal,\n      updateGlobalVersion,\n      updateOne,\n      updateVersion,\n    })\n  }\n\n  return adapter\n}\n\n/**\n * Attempt to find migrations directory.\n *\n * Checks for the following directories in order:\n * - `migrationDir` argument from Payload config\n * - `src/migrations`\n * - `dist/migrations`\n * - `migrations`\n *\n * Defaults to `src/migrations`\n *\n * @param migrationDir\n * @returns\n */\nfunction findMigrationDir(migrationDir?: string): string {\n  const cwd = process.cwd()\n  const srcDir = path.resolve(cwd, 'src/migrations')\n  const distDir = path.resolve(cwd, 'dist/migrations')\n  const relativeMigrations = path.resolve(cwd, 'migrations')\n\n  // Use arg if provided\n  if (migrationDir) return migrationDir\n\n  // Check other common locations\n  if (fs.existsSync(srcDir)) {\n    return srcDir\n  }\n\n  if (fs.existsSync(distDir)) {\n    return distDir\n  }\n\n  if (fs.existsSync(relativeMigrations)) {\n    return relativeMigrations\n  }\n\n  return srcDir\n}\n"],"names":["mongooseAdapter","autoPluralization","connectOptions","disableIndexHints","migrationDir","migrationDirArg","transactionOptions","url","adapter","payload","findMigrationDir","mongoose","set","createDatabaseAdapter","name","collections","connection","undefined","globals","mongoMemoryServer","sessions","versions","beginTransaction","commitTransaction","connect","create","createGlobal","createGlobalVersion","createMigration","createVersion","defaultIDType","deleteMany","deleteOne","deleteVersions","destroy","find","findGlobal","findGlobalVersions","findOne","findVersions","init","migrateFresh","queryDrafts","rollbackTransaction","updateGlobal","updateGlobalVersion","updateOne","updateVersion","cwd","process","srcDir","path","resolve","distDir","relativeMigrations","fs","existsSync"],"rangeMappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;","mappings":";;;;+BA0FgBA;;;eAAAA;;;2DArFD;iEACM;6DACJ;0BACqB;yBAId;wBACD;8BACM;qCACO;iCACJ;+BACF;4BACH;2BACD;gCACK;yBACP;sBACH;4BACM;oCACQ;yBACX;8BACK;sBACR;8BACQ;6BACD;kCACK;mCACC;qCACE;8BACP;qCACO;2BACV;+BACI;;;;;;AAsDvB,SAASA,gBAAgB,EAC9BC,oBAAoB,IAAI,EACxBC,cAAc,EACdC,oBAAoB,KAAK,EACzBC,cAAcC,eAAe,EAC7BC,qBAAqB,CAAC,CAAC,EACvBC,GAAG,EACE;IACL,SAASC,QAAQ,EAAEC,OAAO,EAAwB;QAChD,MAAML,eAAeM,iBAAiBL;QACtCM,iBAAQ,CAACC,GAAG,CAAC,eAAe;QAE5B,OAAOC,IAAAA,+BAAqB,EAAkB;YAC5CC,MAAM;YAEN,oBAAoB;YACpBb;YACAc,aAAa,CAAC;YACdb,gBAAgBA,kBAAkB,CAAC;YACnCc,YAAYC;YACZd;YACAe,SAASD;YACTE,mBAAmBF;YACnBG,UAAU,CAAC;YACXd,oBAAoBA,uBAAuB,QAAQW,YAAYX;YAC/DC;YACAc,UAAU,CAAC;YAEX,kBAAkB;YAClBC,kBAAkBhB,qBAAqBgB,kCAAgB,GAAGL;YAC1DM,mBAAAA,oCAAiB;YACjBC,SAAAA,gBAAO;YACPC,QAAAA,cAAM;YACNC,cAAAA,0BAAY;YACZC,qBAAAA,wCAAmB;YACnBC,iBAAAA,gCAAe;YACfC,eAAAA,4BAAa;YACbC,eAAe;YACfC,YAAAA,sBAAU;YACVC,WAAAA,oBAAS;YACTC,gBAAAA,8BAAc;YACdC,SAAAA,gBAAO;YACPC,MAAAA,UAAI;YACJC,YAAAA,sBAAU;YACVC,oBAAAA,sCAAkB;YAClBC,SAAAA,gBAAO;YACPC,cAAAA,0BAAY;YACZC,MAAAA,UAAI;YACJC,cAAAA,0BAAY;YACZrC;YACAK;YACAiC,aAAAA,wBAAW;YACXC,qBAAAA,wCAAmB;YACnBC,cAAAA,0BAAY;YACZC,qBAAAA,wCAAmB;YACnBC,WAAAA,oBAAS;YACTC,eAAAA,4BAAa;QACf;IACF;IAEA,OAAOvC;AACT;AAEA;;;;;;;;;;;;;CAaC,GACD,SAASE,iBAAiBN,YAAqB;IAC7C,MAAM4C,MAAMC,QAAQD,GAAG;IACvB,MAAME,SAASC,aAAI,CAACC,OAAO,CAACJ,KAAK;IACjC,MAAMK,UAAUF,aAAI,CAACC,OAAO,CAACJ,KAAK;IAClC,MAAMM,qBAAqBH,aAAI,CAACC,OAAO,CAACJ,KAAK;IAE7C,sBAAsB;IACtB,IAAI5C,cAAc,OAAOA;IAEzB,+BAA+B;IAC/B,IAAImD,WAAE,CAACC,UAAU,CAACN,SAAS;QACzB,OAAOA;IACT;IAEA,IAAIK,WAAE,CAACC,UAAU,CAACH,UAAU;QAC1B,OAAOA;IACT;IAEA,IAAIE,WAAE,CAACC,UAAU,CAACF,qBAAqB;QACrC,OAAOA;IACT;IAEA,OAAOJ;AACT"}
131
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../src/index.ts"],"sourcesContent":["import type { TransactionOptions } from 'mongodb'\nimport type { ClientSession, ConnectOptions, Connection } from 'mongoose'\nimport type { Payload } from 'payload'\nimport type { BaseDatabaseAdapter } from 'payload/database'\n\nimport fs from 'fs'\nimport mongoose from 'mongoose'\nimport path from 'path'\nimport { createDatabaseAdapter } from 'payload/database'\n\nimport type { CollectionModel, GlobalModel } from './types'\n\nimport { connect } from './connect'\nimport { count } from './count'\nimport { create } from './create'\nimport { createGlobal } from './createGlobal'\nimport { createGlobalVersion } from './createGlobalVersion'\nimport { createMigration } from './createMigration'\nimport { createVersion } from './createVersion'\nimport { deleteMany } from './deleteMany'\nimport { deleteOne } from './deleteOne'\nimport { deleteVersions } from './deleteVersions'\nimport { destroy } from './destroy'\nimport { find } from './find'\nimport { findGlobal } from './findGlobal'\nimport { findGlobalVersions } from './findGlobalVersions'\nimport { findOne } from './findOne'\nimport { findVersions } from './findVersions'\nimport { init } from './init'\nimport { migrateFresh } from './migrateFresh'\nimport { queryDrafts } from './queryDrafts'\nimport { beginTransaction } from './transactions/beginTransaction'\nimport { commitTransaction } from './transactions/commitTransaction'\nimport { rollbackTransaction } from './transactions/rollbackTransaction'\nimport { updateGlobal } from './updateGlobal'\nimport { updateGlobalVersion } from './updateGlobalVersion'\nimport { updateOne } from './updateOne'\nimport { updateVersion } from './updateVersion'\n\nexport type { MigrateDownArgs, MigrateUpArgs } from './types'\n\nexport interface Args {\n  /** Set to false to disable auto-pluralization of collection names, Defaults to true */\n  autoPluralization?: boolean\n  /** Extra configuration options */\n  connectOptions?: ConnectOptions & {\n    /** Set false to disable $facet aggregation in non-supporting databases, Defaults to true */\n    useFacet?: boolean\n  }\n  /** Set to true to disable hinting to MongoDB to use 'id' as index. This is currently done when counting documents for pagination. Disabling this optimization might fix some problems with AWS DocumentDB. Defaults to false */\n  disableIndexHints?: boolean\n  migrationDir?: string\n  transactionOptions?: TransactionOptions | false\n  /** The URL to connect to MongoDB or false to start payload and prevent connecting */\n  url: false | string\n}\n\nexport type MongooseAdapter = BaseDatabaseAdapter &\n  Args & {\n    collections: {\n      [slug: string]: CollectionModel\n    }\n    connection: Connection\n    globals: GlobalModel\n    mongoMemoryServer: any\n    sessions: Record<number | string, ClientSession>\n    versions: {\n      [slug: string]: CollectionModel\n    }\n  }\n\ntype MongooseAdapterResult = (args: { payload: Payload }) => MongooseAdapter\n\ndeclare module 'payload' {\n  export interface DatabaseAdapter\n    extends Omit<BaseDatabaseAdapter, 'sessions'>,\n      Omit<Args, 'migrationDir'> {\n    collections: {\n      [slug: string]: CollectionModel\n    }\n    connection: Connection\n    globals: GlobalModel\n    mongoMemoryServer: any\n    sessions: Record<number | string, ClientSession>\n    transactionOptions: TransactionOptions\n    versions: {\n      [slug: string]: CollectionModel\n    }\n  }\n}\n\nexport function mongooseAdapter({\n  autoPluralization = true,\n  connectOptions,\n  disableIndexHints = false,\n  migrationDir: migrationDirArg,\n  transactionOptions = {},\n  url,\n}: Args): MongooseAdapterResult {\n  function adapter({ payload }: { payload: Payload }) {\n    const migrationDir = findMigrationDir(migrationDirArg)\n    mongoose.set('strictQuery', false)\n\n    return createDatabaseAdapter<MongooseAdapter>({\n      name: 'mongoose',\n\n      // Mongoose-specific\n      autoPluralization,\n      collections: {},\n      connectOptions: connectOptions || {},\n      connection: undefined,\n      count,\n      disableIndexHints,\n      globals: undefined,\n      mongoMemoryServer: undefined,\n      sessions: {},\n      transactionOptions: transactionOptions === false ? undefined : transactionOptions,\n      url,\n      versions: {},\n      // DatabaseAdapter\n      beginTransaction: transactionOptions ? beginTransaction : undefined,\n      commitTransaction,\n      connect,\n      create,\n      createGlobal,\n      createGlobalVersion,\n      createMigration,\n      createVersion,\n      defaultIDType: 'text',\n      deleteMany,\n      deleteOne,\n      deleteVersions,\n      destroy,\n      find,\n      findGlobal,\n      findGlobalVersions,\n      findOne,\n      findVersions,\n      init,\n      migrateFresh,\n      migrationDir,\n      payload,\n      queryDrafts,\n      rollbackTransaction,\n      updateGlobal,\n      updateGlobalVersion,\n      updateOne,\n      updateVersion,\n    })\n  }\n\n  return adapter\n}\n\n/**\n * Attempt to find migrations directory.\n *\n * Checks for the following directories in order:\n * - `migrationDir` argument from Payload config\n * - `src/migrations`\n * - `dist/migrations`\n * - `migrations`\n *\n * Defaults to `src/migrations`\n *\n * @param migrationDir\n * @returns\n */\nfunction findMigrationDir(migrationDir?: string): string {\n  const cwd = process.cwd()\n  const srcDir = path.resolve(cwd, 'src/migrations')\n  const distDir = path.resolve(cwd, 'dist/migrations')\n  const relativeMigrations = path.resolve(cwd, 'migrations')\n\n  // Use arg if provided\n  if (migrationDir) return migrationDir\n\n  // Check other common locations\n  if (fs.existsSync(srcDir)) {\n    return srcDir\n  }\n\n  if (fs.existsSync(distDir)) {\n    return distDir\n  }\n\n  if (fs.existsSync(relativeMigrations)) {\n    return relativeMigrations\n  }\n\n  return srcDir\n}\n"],"names":["mongooseAdapter","autoPluralization","connectOptions","disableIndexHints","migrationDir","migrationDirArg","transactionOptions","url","adapter","payload","findMigrationDir","mongoose","set","createDatabaseAdapter","name","collections","connection","undefined","count","globals","mongoMemoryServer","sessions","versions","beginTransaction","commitTransaction","connect","create","createGlobal","createGlobalVersion","createMigration","createVersion","defaultIDType","deleteMany","deleteOne","deleteVersions","destroy","find","findGlobal","findGlobalVersions","findOne","findVersions","init","migrateFresh","queryDrafts","rollbackTransaction","updateGlobal","updateGlobalVersion","updateOne","updateVersion","cwd","process","srcDir","path","resolve","distDir","relativeMigrations","fs","existsSync"],"rangeMappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;","mappings":";;;;+BA2FgBA;;;eAAAA;;;2DAtFD;iEACM;6DACJ;0BACqB;yBAId;uBACF;wBACC;8BACM;qCACO;iCACJ;+BACF;4BACH;2BACD;gCACK;yBACP;sBACH;4BACM;oCACQ;yBACX;8BACK;sBACR;8BACQ;6BACD;kCACK;mCACC;qCACE;8BACP;qCACO;2BACV;+BACI;;;;;;AAsDvB,SAASA,gBAAgB,EAC9BC,oBAAoB,IAAI,EACxBC,cAAc,EACdC,oBAAoB,KAAK,EACzBC,cAAcC,eAAe,EAC7BC,qBAAqB,CAAC,CAAC,EACvBC,GAAG,EACE;IACL,SAASC,QAAQ,EAAEC,OAAO,EAAwB;QAChD,MAAML,eAAeM,iBAAiBL;QACtCM,iBAAQ,CAACC,GAAG,CAAC,eAAe;QAE5B,OAAOC,IAAAA,+BAAqB,EAAkB;YAC5CC,MAAM;YAEN,oBAAoB;YACpBb;YACAc,aAAa,CAAC;YACdb,gBAAgBA,kBAAkB,CAAC;YACnCc,YAAYC;YACZC,OAAAA,YAAK;YACLf;YACAgB,SAASF;YACTG,mBAAmBH;YACnBI,UAAU,CAAC;YACXf,oBAAoBA,uBAAuB,QAAQW,YAAYX;YAC/DC;YACAe,UAAU,CAAC;YACX,kBAAkB;YAClBC,kBAAkBjB,qBAAqBiB,kCAAgB,GAAGN;YAC1DO,mBAAAA,oCAAiB;YACjBC,SAAAA,gBAAO;YACPC,QAAAA,cAAM;YACNC,cAAAA,0BAAY;YACZC,qBAAAA,wCAAmB;YACnBC,iBAAAA,gCAAe;YACfC,eAAAA,4BAAa;YACbC,eAAe;YACfC,YAAAA,sBAAU;YACVC,WAAAA,oBAAS;YACTC,gBAAAA,8BAAc;YACdC,SAAAA,gBAAO;YACPC,MAAAA,UAAI;YACJC,YAAAA,sBAAU;YACVC,oBAAAA,sCAAkB;YAClBC,SAAAA,gBAAO;YACPC,cAAAA,0BAAY;YACZC,MAAAA,UAAI;YACJC,cAAAA,0BAAY;YACZtC;YACAK;YACAkC,aAAAA,wBAAW;YACXC,qBAAAA,wCAAmB;YACnBC,cAAAA,0BAAY;YACZC,qBAAAA,wCAAmB;YACnBC,WAAAA,oBAAS;YACTC,eAAAA,4BAAa;QACf;IACF;IAEA,OAAOxC;AACT;AAEA;;;;;;;;;;;;;CAaC,GACD,SAASE,iBAAiBN,YAAqB;IAC7C,MAAM6C,MAAMC,QAAQD,GAAG;IACvB,MAAME,SAASC,aAAI,CAACC,OAAO,CAACJ,KAAK;IACjC,MAAMK,UAAUF,aAAI,CAACC,OAAO,CAACJ,KAAK;IAClC,MAAMM,qBAAqBH,aAAI,CAACC,OAAO,CAACJ,KAAK;IAE7C,sBAAsB;IACtB,IAAI7C,cAAc,OAAOA;IAEzB,+BAA+B;IAC/B,IAAIoD,WAAE,CAACC,UAAU,CAACN,SAAS;QACzB,OAAOA;IACT;IAEA,IAAIK,WAAE,CAACC,UAAU,CAACH,UAAU;QAC1B,OAAOA;IACT;IAEA,IAAIE,WAAE,CAACC,UAAU,CAACF,qBAAqB;QACrC,OAAOA;IACT;IAEA,OAAOJ;AACT"}
@@ -1 +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;eACZ,MAAM;eACN,OAAO;UACZ,OAAO;CAgKd,CAAA"}
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;AA8CD,eAAO,MAAM,kBAAkB,iDAM5B,sBAAsB;eACZ,MAAM;eACN,OAAO;UACZ,OAAO;CA8Jd,CAAA"}
@@ -15,6 +15,61 @@ function _interop_require_default(obj) {
15
15
  default: obj
16
16
  };
17
17
  }
18
+ const handleHasManyValues = (formattedValue)=>{
19
+ return formattedValue.reduce((formattedValues, inVal)=>{
20
+ const newValues = [
21
+ inVal
22
+ ];
23
+ if (_mongoose.default.Types.ObjectId.isValid(inVal)) {
24
+ newValues.push(new _mongoose.default.Types.ObjectId(inVal));
25
+ }
26
+ const parsedNumber = parseFloat(inVal);
27
+ if (!Number.isNaN(parsedNumber)) {
28
+ newValues.push(parsedNumber);
29
+ }
30
+ return [
31
+ ...formattedValues,
32
+ ...newValues
33
+ ];
34
+ }, []);
35
+ };
36
+ const handleNonHasManyValues = (formattedValue, operator, path)=>{
37
+ const formattedQueries = formattedValue.map((inVal)=>{
38
+ if (inVal && typeof inVal === 'object' && 'relationTo' in inVal && 'value' in inVal) {
39
+ if (operator === 'in') {
40
+ return {
41
+ [`${path}.relationTo`]: {
42
+ $eq: inVal.relationTo
43
+ },
44
+ [`${path}.value`]: {
45
+ $eq: inVal.value
46
+ }
47
+ };
48
+ } else if (operator === 'not_in') {
49
+ return {
50
+ $and: [
51
+ {
52
+ [`${path}.value`]: inVal.value
53
+ },
54
+ {
55
+ [`${path}.relationTo`]: inVal.relationTo
56
+ }
57
+ ]
58
+ };
59
+ }
60
+ }
61
+ return null;
62
+ }).filter(Boolean);
63
+ if (formattedQueries.length > 0) {
64
+ return {
65
+ rawQuery: operator === 'in' ? {
66
+ $or: formattedQueries
67
+ } : {
68
+ $nor: formattedQueries
69
+ }
70
+ };
71
+ }
72
+ };
18
73
  const sanitizeQueryValue = ({ field, hasCustomID, operator, path, val })=>{
19
74
  let formattedValue = val;
20
75
  let formattedOperator = operator;
@@ -89,19 +144,18 @@ const sanitizeQueryValue = ({ field, hasCustomID, operator, path, val })=>{
89
144
  }
90
145
  };
91
146
  }
92
- if (operator === 'in' && Array.isArray(formattedValue)) {
93
- formattedValue = formattedValue.reduce((formattedValues, inVal)=>{
94
- const newValues = [
95
- inVal
96
- ];
97
- if (_mongoose.default.Types.ObjectId.isValid(inVal)) newValues.push(new _mongoose.default.Types.ObjectId(inVal));
98
- const parsedNumber = parseFloat(inVal);
99
- if (!Number.isNaN(parsedNumber)) newValues.push(parsedNumber);
100
- return [
101
- ...formattedValues,
102
- ...newValues
103
- ];
104
- }, []);
147
+ if ([
148
+ 'in',
149
+ 'not_in'
150
+ ].includes(operator) && Array.isArray(formattedValue)) {
151
+ if ('hasMany' in field && field.hasMany) {
152
+ formattedValue = handleHasManyValues(formattedValue);
153
+ } else {
154
+ const result = handleNonHasManyValues(formattedValue, operator, path);
155
+ if (result) {
156
+ return result;
157
+ }
158
+ }
105
159
  }
106
160
  }
107
161
  // Set up specific formatting necessary by operators
@@ -199,4 +253,4 @@ const sanitizeQueryValue = ({ field, hasCustomID, operator, path, val })=>{
199
253
  };
200
254
  };
201
255
 
202
- //# 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): {\n  operator?: string\n  rawQuery?: unknown\n  val?: unknown\n} => {\n  let formattedValue = val\n  let formattedOperator = operator\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 { operator: formattedOperator, val: undefined }\n      }\n    }\n\n    if (field.type === 'number') {\n      const parsedNumber = parseFloat(val)\n\n      if (Number.isNaN(parsedNumber)) {\n        return { operator: formattedOperator, val: 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' && operator !== 'exists') {\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    // Object equality requires the value to be the first key in the object that is being queried.\n    if (\n      operator === 'equals' &&\n      formattedValue &&\n      typeof formattedValue === 'object' &&\n      formattedValue.value &&\n      formattedValue.relationTo\n    ) {\n      return {\n        rawQuery: {\n          $and: [\n            { [`${path}.value`]: { $eq: formattedValue.value } },\n            { [`${path}.relationTo`]: { $eq: formattedValue.relationTo } },\n          ],\n        },\n      }\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: { type: 'Point', coordinates: [parseFloat(lng), parseFloat(lat)] },\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 = {\n        $options: 'i',\n        $regex: formattedValue.replace(/[\\\\^$*+?.()|[\\]{}]/g, '\\\\$&'),\n      }\n    }\n  }\n\n  if (\n    (path === '_id' || path === 'parent') &&\n    operator === 'like' &&\n    formattedValue.length === 24 &&\n    !hasCustomID\n  ) {\n    formattedOperator = 'equals'\n  }\n\n  if (operator === 'exists') {\n    formattedValue = formattedValue === 'true' || formattedValue === true\n\n    // Clearable fields\n    if (['relationship', 'select', 'upload'].includes(field.type)) {\n      if (formattedValue) {\n        return {\n          rawQuery: {\n            $and: [{ [path]: { $exists: true } }, { [path]: { $ne: null } }],\n          },\n        }\n      } else {\n        return {\n          rawQuery: {\n            $or: [{ [path]: { $exists: false } }, { [path]: { $eq: null } }],\n          },\n        }\n      }\n    }\n  }\n\n  return { operator: formattedOperator, val: formattedValue }\n}\n"],"names":["sanitizeQueryValue","field","hasCustomID","operator","path","val","formattedValue","formattedOperator","split","length","isValid","mongoose","Types","ObjectId","undefined","type","parsedNumber","parseFloat","Number","isNaN","toLowerCase","includes","createArrayFromCommaDelineated","map","arrayVal","Date","parse","value","relationTo","rawQuery","$and","$eq","Array","isArray","reduce","formattedValues","inVal","newValues","push","lng","lat","maxDistance","minDistance","$geometry","coordinates","$maxDistance","$minDistance","$options","$regex","replace","$exists","$ne","$or"],"rangeMappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;","mappings":"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"}
256
+ //# 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\nconst handleHasManyValues = (formattedValue) => {\n  return 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)) {\n      newValues.push(parsedNumber)\n    }\n\n    return [...formattedValues, ...newValues]\n  }, [])\n}\n\nconst handleNonHasManyValues = (formattedValue, operator, path) => {\n  const formattedQueries = formattedValue\n    .map((inVal) => {\n      if (inVal && typeof inVal === 'object' && 'relationTo' in inVal && 'value' in inVal) {\n        if (operator === 'in') {\n          return {\n            [`${path}.relationTo`]: { $eq: inVal.relationTo },\n            [`${path}.value`]: { $eq: inVal.value },\n          }\n        } else if (operator === 'not_in') {\n          return {\n            $and: [\n              { [`${path}.value`]: inVal.value },\n              { [`${path}.relationTo`]: inVal.relationTo },\n            ],\n          }\n        }\n      }\n      return null\n    })\n    .filter(Boolean)\n\n  if (formattedQueries.length > 0) {\n    return {\n      rawQuery: operator === 'in' ? { $or: formattedQueries } : { $nor: formattedQueries },\n    }\n  }\n}\n\nexport const sanitizeQueryValue = ({\n  field,\n  hasCustomID,\n  operator,\n  path,\n  val,\n}: SanitizeQueryValueArgs): {\n  operator?: string\n  rawQuery?: unknown\n  val?: unknown\n} => {\n  let formattedValue = val\n  let formattedOperator = operator\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 { operator: formattedOperator, val: undefined }\n      }\n    }\n\n    if (field.type === 'number') {\n      const parsedNumber = parseFloat(val)\n\n      if (Number.isNaN(parsedNumber)) {\n        return { operator: formattedOperator, val: 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' && operator !== 'exists') {\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    // Object equality requires the value to be the first key in the object that is being queried.\n    if (\n      operator === 'equals' &&\n      formattedValue &&\n      typeof formattedValue === 'object' &&\n      formattedValue.value &&\n      formattedValue.relationTo\n    ) {\n      return {\n        rawQuery: {\n          $and: [\n            { [`${path}.value`]: { $eq: formattedValue.value } },\n            { [`${path}.relationTo`]: { $eq: formattedValue.relationTo } },\n          ],\n        },\n      }\n    }\n\n    if (['in', 'not_in'].includes(operator) && Array.isArray(formattedValue)) {\n      if ('hasMany' in field && field.hasMany) {\n        formattedValue = handleHasManyValues(formattedValue)\n      } else {\n        const result = handleNonHasManyValues(formattedValue, operator, path)\n        if (result) {\n          return result\n        }\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: { type: 'Point', coordinates: [parseFloat(lng), parseFloat(lat)] },\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 = {\n        $options: 'i',\n        $regex: formattedValue.replace(/[\\\\^$*+?.()|[\\]{}]/g, '\\\\$&'),\n      }\n    }\n  }\n\n  if (\n    (path === '_id' || path === 'parent') &&\n    operator === 'like' &&\n    formattedValue.length === 24 &&\n    !hasCustomID\n  ) {\n    formattedOperator = 'equals'\n  }\n\n  if (operator === 'exists') {\n    formattedValue = formattedValue === 'true' || formattedValue === true\n\n    // Clearable fields\n    if (['relationship', 'select', 'upload'].includes(field.type)) {\n      if (formattedValue) {\n        return {\n          rawQuery: {\n            $and: [{ [path]: { $exists: true } }, { [path]: { $ne: null } }],\n          },\n        }\n      } else {\n        return {\n          rawQuery: {\n            $or: [{ [path]: { $exists: false } }, { [path]: { $eq: null } }],\n          },\n        }\n      }\n    }\n  }\n\n  return { operator: formattedOperator, val: formattedValue }\n}\n"],"names":["sanitizeQueryValue","handleHasManyValues","formattedValue","reduce","formattedValues","inVal","newValues","mongoose","Types","ObjectId","isValid","push","parsedNumber","parseFloat","Number","isNaN","handleNonHasManyValues","operator","path","formattedQueries","map","$eq","relationTo","value","$and","filter","Boolean","length","rawQuery","$or","$nor","field","hasCustomID","val","formattedOperator","split","undefined","type","toLowerCase","includes","createArrayFromCommaDelineated","arrayVal","Date","parse","Array","isArray","hasMany","result","lng","lat","maxDistance","minDistance","$geometry","coordinates","$maxDistance","$minDistance","$options","$regex","replace","$exists","$ne"],"rangeMappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;","mappings":"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"}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@payloadcms/db-mongodb",
3
- "version": "1.5.0",
3
+ "version": "1.5.2",
4
4
  "description": "The officially supported MongoDB database adapter for Payload",
5
5
  "repository": {
6
6
  "type": "git",
@@ -32,7 +32,7 @@
32
32
  "mongodb": "4.17.1",
33
33
  "mongodb-memory-server": "^9",
34
34
  "@payloadcms/eslint-config": "1.1.1",
35
- "payload": "2.13.0"
35
+ "payload": "2.22.0"
36
36
  },
37
37
  "peerDependencies": {
38
38
  "payload": "^2.0.0"