@payloadcms/db-mongodb 1.7.1 → 1.7.3

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.
@@ -1 +1 @@
1
- {"version":3,"file":"buildSearchParams.d.ts","sourceRoot":"","sources":["../../src/queries/buildSearchParams.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,OAAO,EAAE,MAAM,SAAS,CAAA;AAEtC,OAAO,KAAK,EAAE,KAAK,EAAE,MAAM,eAAe,CAAA;AAc1C,KAAK,WAAW,GAAG;IACjB,IAAI,CAAC,EAAE,MAAM,CAAA;IACb,QAAQ,CAAC,EAAE,OAAO,CAAA;IAClB,KAAK,CAAC,EAAE,OAAO,CAAA;CAChB,CAAA;AAOD;;GAEG;AACH,wBAAsB,gBAAgB,CAAC,EACrC,cAAc,EACd,MAAM,EACN,UAAU,EACV,YAAY,EACZ,MAAM,EACN,QAAQ,EACR,OAAO,EACP,GAAG,GACJ,EAAE;IACD,cAAc,CAAC,EAAE,MAAM,CAAA;IACvB,MAAM,EAAE,KAAK,EAAE,CAAA;IACf,UAAU,CAAC,EAAE,MAAM,CAAA;IACnB,YAAY,EAAE,MAAM,CAAA;IACpB,MAAM,CAAC,EAAE,MAAM,CAAA;IACf,QAAQ,EAAE,MAAM,CAAA;IAChB,OAAO,EAAE,OAAO,CAAA;IAChB,GAAG,EAAE,OAAO,CAAA;CACb,GAAG,OAAO,CAAC,WAAW,CAAC,CA6NvB"}
1
+ {"version":3,"file":"buildSearchParams.d.ts","sourceRoot":"","sources":["../../src/queries/buildSearchParams.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,OAAO,EAAE,MAAM,SAAS,CAAA;AAEtC,OAAO,KAAK,EAAE,KAAK,EAAE,MAAM,eAAe,CAAA;AAgB1C,KAAK,WAAW,GAAG;IACjB,IAAI,CAAC,EAAE,MAAM,CAAA;IACb,QAAQ,CAAC,EAAE,OAAO,CAAA;IAClB,KAAK,CAAC,EAAE,OAAO,CAAA;CAChB,CAAA;AAOD;;GAEG;AACH,wBAAsB,gBAAgB,CAAC,EACrC,cAAc,EACd,MAAM,EACN,UAAU,EACV,YAAY,EACZ,MAAM,EACN,QAAQ,EACR,OAAO,EACP,GAAG,GACJ,EAAE;IACD,cAAc,CAAC,EAAE,MAAM,CAAA;IACvB,MAAM,EAAE,KAAK,EAAE,CAAA;IACf,UAAU,CAAC,EAAE,MAAM,CAAA;IACnB,YAAY,EAAE,MAAM,CAAA;IACpB,MAAM,CAAC,EAAE,MAAM,CAAA;IACf,QAAQ,EAAE,MAAM,CAAA;IAChB,OAAO,EAAE,OAAO,CAAA;IAChB,GAAG,EAAE,OAAO,CAAA;CACb,GAAG,OAAO,CAAC,WAAW,CAAC,CAmOvB"}
@@ -19,6 +19,7 @@ function _interop_require_default(obj) {
19
19
  default: obj
20
20
  };
21
21
  }
22
+ const ObjectId = _bsonobjectid.default;
22
23
  const subQueryOptions = {
23
24
  lean: true,
24
25
  limit: 50
@@ -146,9 +147,11 @@ async function buildSearchParam({ collectionSlug, fields, globalSlug, incomingPa
146
147
  const operatorKey = _operatorMap.operatorMap[formattedOperator];
147
148
  if (field.type === 'relationship' || field.type === 'upload') {
148
149
  let hasNumberIDRelation;
150
+ let multiIDCondition = '$or';
151
+ if (operatorKey === '$ne') multiIDCondition = '$and';
149
152
  const result = {
150
153
  value: {
151
- $or: [
154
+ [multiIDCondition]: [
152
155
  {
153
156
  [path]: {
154
157
  [operatorKey]: formattedValue
@@ -159,9 +162,9 @@ async function buildSearchParam({ collectionSlug, fields, globalSlug, incomingPa
159
162
  };
160
163
  if (typeof formattedValue === 'string') {
161
164
  if (_mongoose.default.Types.ObjectId.isValid(formattedValue)) {
162
- result.value.$or.push({
165
+ result.value[multiIDCondition].push({
163
166
  [path]: {
164
- [operatorKey]: (0, _bsonobjectid.default)(formattedValue)
167
+ [operatorKey]: ObjectId(formattedValue)
165
168
  }
166
169
  });
167
170
  } else {
@@ -175,14 +178,14 @@ async function buildSearchParam({ collectionSlug, fields, globalSlug, incomingPa
175
178
  if (isRelatedToCustomNumberID.type === 'number') hasNumberIDRelation = true;
176
179
  }
177
180
  });
178
- if (hasNumberIDRelation) result.value.$or.push({
181
+ if (hasNumberIDRelation) result.value[multiIDCondition].push({
179
182
  [path]: {
180
183
  [operatorKey]: parseFloat(formattedValue)
181
184
  }
182
185
  });
183
186
  }
184
187
  }
185
- if (result.value.$or.length > 1) {
188
+ if (result.value[multiIDCondition].length > 1) {
186
189
  return result;
187
190
  }
188
191
  }
@@ -219,4 +222,4 @@ async function buildSearchParam({ collectionSlug, fields, globalSlug, incomingPa
219
222
  return undefined;
220
223
  }
221
224
 
222
- //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../src/queries/buildSearchParams.ts"],"sourcesContent":["import type { Payload } from 'payload'\nimport type { PathToQuery } from 'payload/database'\nimport type { Field } from 'payload/types'\nimport type { Operator } from 'payload/types'\n\nimport objectID from 'bson-objectid'\nimport mongoose from 'mongoose'\nimport { getLocalizedPaths } from 'payload/database'\nimport { fieldAffectsData } from 'payload/types'\nimport { validOperators } from 'payload/types'\n\nimport type { MongooseAdapter } from '..'\n\nimport { operatorMap } from './operatorMap'\nimport { sanitizeQueryValue } from './sanitizeQueryValue'\n\ntype SearchParam = {\n  path?: string\n  rawQuery?: unknown\n  value?: unknown\n}\n\nconst subQueryOptions = {\n  lean: true,\n  limit: 50,\n}\n\n/**\n * Convert the Payload key / value / operator into a MongoDB query\n */\nexport async function buildSearchParam({\n  collectionSlug,\n  fields,\n  globalSlug,\n  incomingPath,\n  locale,\n  operator,\n  payload,\n  val,\n}: {\n  collectionSlug?: string\n  fields: Field[]\n  globalSlug?: string\n  incomingPath: string\n  locale?: string\n  operator: string\n  payload: Payload\n  val: unknown\n}): Promise<SearchParam> {\n  // Replace GraphQL nested field double underscore formatting\n  let sanitizedPath = incomingPath.replace(/__/g, '.')\n  if (sanitizedPath === 'id') sanitizedPath = '_id'\n\n  let paths: PathToQuery[] = []\n\n  let hasCustomID = false\n\n  if (sanitizedPath === '_id') {\n    const customIDfield = payload.collections[collectionSlug]?.config.fields.find(\n      (field) => fieldAffectsData(field) && field.name === 'id',\n    )\n\n    let idFieldType: 'number' | 'text' = 'text'\n\n    if (customIDfield) {\n      if (customIDfield?.type === 'text' || customIDfield?.type === 'number') {\n        idFieldType = customIDfield.type\n      }\n\n      hasCustomID = true\n    }\n\n    paths.push({\n      collectionSlug,\n      complete: true,\n      field: {\n        name: 'id',\n        type: idFieldType,\n      } as Field,\n      path: '_id',\n    })\n  } else {\n    paths = await getLocalizedPaths({\n      collectionSlug,\n      fields,\n      globalSlug,\n      incomingPath: sanitizedPath,\n      locale,\n      payload,\n    })\n  }\n\n  const [{ field, path }] = paths\n\n  if (path) {\n    const {\n      operator: formattedOperator,\n      rawQuery,\n      val: formattedValue,\n    } = sanitizeQueryValue({\n      field,\n      hasCustomID,\n      operator,\n      path,\n      val,\n    })\n\n    if (rawQuery) return { value: rawQuery }\n\n    // If there are multiple collections to search through,\n    // Recursively build up a list of query constraints\n    if (paths.length > 1) {\n      // Remove top collection and reverse array\n      // to work backwards from top\n      const pathsToQuery = paths.slice(1).reverse()\n\n      const initialRelationshipQuery = {\n        value: {},\n      } as SearchParam\n\n      const relationshipQuery = await pathsToQuery.reduce(\n        async (priorQuery, { collectionSlug: slug, path: subPath }, i) => {\n          const priorQueryResult = await priorQuery\n\n          const SubModel = (payload.db as MongooseAdapter).collections[slug]\n\n          // On the \"deepest\" collection,\n          // Search on the value passed through the query\n          if (i === 0) {\n            const subQuery = await SubModel.buildQuery({\n              locale,\n              payload,\n              where: {\n                [subPath]: {\n                  [formattedOperator]: val,\n                },\n              },\n            })\n\n            const result = await SubModel.find(subQuery, subQueryOptions)\n\n            const $in: unknown[] = []\n\n            result.forEach((doc) => {\n              const stringID = doc._id.toString()\n              $in.push(stringID)\n\n              if (mongoose.Types.ObjectId.isValid(stringID)) {\n                $in.push(doc._id)\n              }\n            })\n\n            if (pathsToQuery.length === 1) {\n              return {\n                path,\n                value: { $in },\n              }\n            }\n\n            const nextSubPath = pathsToQuery[i + 1].path\n\n            return {\n              value: { [nextSubPath]: { $in } },\n            }\n          }\n\n          const subQuery = priorQueryResult.value\n          const result = await SubModel.find(subQuery, subQueryOptions)\n\n          const $in = result.map((doc) => doc._id.toString())\n\n          // If it is the last recursion\n          // then pass through the search param\n          if (i + 1 === pathsToQuery.length) {\n            return {\n              path,\n              value: { $in },\n            }\n          }\n\n          return {\n            value: {\n              _id: { $in },\n            },\n          }\n        },\n        Promise.resolve(initialRelationshipQuery),\n      )\n\n      return relationshipQuery\n    }\n\n    if (formattedOperator && validOperators.includes(formattedOperator as Operator)) {\n      const operatorKey = operatorMap[formattedOperator]\n\n      if (field.type === 'relationship' || field.type === 'upload') {\n        let hasNumberIDRelation\n\n        const result = {\n          value: {\n            $or: [{ [path]: { [operatorKey]: formattedValue } }],\n          },\n        }\n\n        if (typeof formattedValue === 'string') {\n          if (mongoose.Types.ObjectId.isValid(formattedValue)) {\n            result.value.$or.push({ [path]: { [operatorKey]: objectID(formattedValue) } })\n          } else {\n            ;(Array.isArray(field.relationTo) ? field.relationTo : [field.relationTo]).forEach(\n              (relationTo) => {\n                const isRelatedToCustomNumberID = payload.collections[\n                  relationTo\n                ]?.config?.fields.find((relatedField) => {\n                  return (\n                    fieldAffectsData(relatedField) &&\n                    relatedField.name === 'id' &&\n                    relatedField.type === 'number'\n                  )\n                })\n\n                if (isRelatedToCustomNumberID) {\n                  if (isRelatedToCustomNumberID.type === 'number') hasNumberIDRelation = true\n                }\n              },\n            )\n\n            if (hasNumberIDRelation)\n              result.value.$or.push({ [path]: { [operatorKey]: parseFloat(formattedValue) } })\n          }\n        }\n\n        if (result.value.$or.length > 1) {\n          return result\n        }\n      }\n\n      if (formattedOperator === 'like' && typeof formattedValue === 'string') {\n        const words = formattedValue.split(' ')\n\n        const result = {\n          value: {\n            $and: words.map((word) => ({\n              [path]: {\n                $options: 'i',\n                $regex: word.replace(/[\\\\^$*+?.()|[\\]{}]/g, '\\\\$&'),\n              },\n            })),\n          },\n        }\n\n        return result\n      }\n\n      // Some operators like 'near' need to define a full query\n      // so if there is no operator key, just return the value\n      if (!operatorKey) {\n        return {\n          path,\n          value: formattedValue,\n        }\n      }\n\n      return {\n        path,\n        value: { [operatorKey]: formattedValue },\n      }\n    }\n  }\n  return undefined\n}\n"],"names":["buildSearchParam","subQueryOptions","lean","limit","collectionSlug","fields","globalSlug","incomingPath","locale","operator","payload","val","sanitizedPath","replace","paths","hasCustomID","customIDfield","collections","config","find","field","fieldAffectsData","name","idFieldType","type","push","complete","path","getLocalizedPaths","formattedOperator","rawQuery","formattedValue","sanitizeQueryValue","value","length","pathsToQuery","slice","reverse","initialRelationshipQuery","relationshipQuery","reduce","priorQuery","slug","subPath","i","priorQueryResult","SubModel","db","subQuery","buildQuery","where","result","$in","forEach","doc","stringID","_id","toString","mongoose","Types","ObjectId","isValid","nextSubPath","map","Promise","resolve","validOperators","includes","operatorKey","operatorMap","hasNumberIDRelation","$or","objectID","Array","isArray","relationTo","isRelatedToCustomNumberID","relatedField","parseFloat","words","split","$and","word","$options","$regex","undefined"],"rangeMappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;","mappings":"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"}
225
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../src/queries/buildSearchParams.ts"],"sourcesContent":["import type { Payload } from 'payload'\nimport type { PathToQuery } from 'payload/database'\nimport type { Field } from 'payload/types'\nimport type { Operator } from 'payload/types'\n\nimport ObjectIdImport from 'bson-objectid'\nimport mongoose from 'mongoose'\nimport { getLocalizedPaths } from 'payload/database'\nimport { fieldAffectsData } from 'payload/types'\nimport { validOperators } from 'payload/types'\n\nimport type { MongooseAdapter } from '..'\n\nimport { operatorMap } from './operatorMap'\nimport { sanitizeQueryValue } from './sanitizeQueryValue'\n\nconst ObjectId = ObjectIdImport\n\ntype SearchParam = {\n  path?: string\n  rawQuery?: unknown\n  value?: unknown\n}\n\nconst subQueryOptions = {\n  lean: true,\n  limit: 50,\n}\n\n/**\n * Convert the Payload key / value / operator into a MongoDB query\n */\nexport async function buildSearchParam({\n  collectionSlug,\n  fields,\n  globalSlug,\n  incomingPath,\n  locale,\n  operator,\n  payload,\n  val,\n}: {\n  collectionSlug?: string\n  fields: Field[]\n  globalSlug?: string\n  incomingPath: string\n  locale?: string\n  operator: string\n  payload: Payload\n  val: unknown\n}): Promise<SearchParam> {\n  // Replace GraphQL nested field double underscore formatting\n  let sanitizedPath = incomingPath.replace(/__/g, '.')\n  if (sanitizedPath === 'id') sanitizedPath = '_id'\n\n  let paths: PathToQuery[] = []\n\n  let hasCustomID = false\n\n  if (sanitizedPath === '_id') {\n    const customIDfield = payload.collections[collectionSlug]?.config.fields.find(\n      (field) => fieldAffectsData(field) && field.name === 'id',\n    )\n\n    let idFieldType: 'number' | 'text' = 'text'\n\n    if (customIDfield) {\n      if (customIDfield?.type === 'text' || customIDfield?.type === 'number') {\n        idFieldType = customIDfield.type\n      }\n\n      hasCustomID = true\n    }\n\n    paths.push({\n      collectionSlug,\n      complete: true,\n      field: {\n        name: 'id',\n        type: idFieldType,\n      } as Field,\n      path: '_id',\n    })\n  } else {\n    paths = await getLocalizedPaths({\n      collectionSlug,\n      fields,\n      globalSlug,\n      incomingPath: sanitizedPath,\n      locale,\n      payload,\n    })\n  }\n\n  const [{ field, path }] = paths\n\n  if (path) {\n    const {\n      operator: formattedOperator,\n      rawQuery,\n      val: formattedValue,\n    } = sanitizeQueryValue({\n      field,\n      hasCustomID,\n      operator,\n      path,\n      val,\n    })\n\n    if (rawQuery) return { value: rawQuery }\n\n    // If there are multiple collections to search through,\n    // Recursively build up a list of query constraints\n    if (paths.length > 1) {\n      // Remove top collection and reverse array\n      // to work backwards from top\n      const pathsToQuery = paths.slice(1).reverse()\n\n      const initialRelationshipQuery = {\n        value: {},\n      } as SearchParam\n\n      const relationshipQuery = await pathsToQuery.reduce(\n        async (priorQuery, { collectionSlug: slug, path: subPath }, i) => {\n          const priorQueryResult = await priorQuery\n\n          const SubModel = (payload.db as MongooseAdapter).collections[slug]\n\n          // On the \"deepest\" collection,\n          // Search on the value passed through the query\n          if (i === 0) {\n            const subQuery = await SubModel.buildQuery({\n              locale,\n              payload,\n              where: {\n                [subPath]: {\n                  [formattedOperator]: val,\n                },\n              },\n            })\n\n            const result = await SubModel.find(subQuery, subQueryOptions)\n\n            const $in: unknown[] = []\n\n            result.forEach((doc) => {\n              const stringID = doc._id.toString()\n              $in.push(stringID)\n\n              if (mongoose.Types.ObjectId.isValid(stringID)) {\n                $in.push(doc._id)\n              }\n            })\n\n            if (pathsToQuery.length === 1) {\n              return {\n                path,\n                value: { $in },\n              }\n            }\n\n            const nextSubPath = pathsToQuery[i + 1].path\n\n            return {\n              value: { [nextSubPath]: { $in } },\n            }\n          }\n\n          const subQuery = priorQueryResult.value\n          const result = await SubModel.find(subQuery, subQueryOptions)\n\n          const $in = result.map((doc) => doc._id.toString())\n\n          // If it is the last recursion\n          // then pass through the search param\n          if (i + 1 === pathsToQuery.length) {\n            return {\n              path,\n              value: { $in },\n            }\n          }\n\n          return {\n            value: {\n              _id: { $in },\n            },\n          }\n        },\n        Promise.resolve(initialRelationshipQuery),\n      )\n\n      return relationshipQuery\n    }\n\n    if (formattedOperator && validOperators.includes(formattedOperator as Operator)) {\n      const operatorKey = operatorMap[formattedOperator]\n\n      if (field.type === 'relationship' || field.type === 'upload') {\n        let hasNumberIDRelation\n        let multiIDCondition = '$or'\n        if (operatorKey === '$ne') multiIDCondition = '$and'\n\n        const result = {\n          value: {\n            [multiIDCondition]: [{ [path]: { [operatorKey]: formattedValue } }],\n          },\n        }\n\n        if (typeof formattedValue === 'string') {\n          if (mongoose.Types.ObjectId.isValid(formattedValue)) {\n            result.value[multiIDCondition].push({\n              [path]: { [operatorKey]: ObjectId(formattedValue) },\n            })\n          } else {\n            ;(Array.isArray(field.relationTo) ? field.relationTo : [field.relationTo]).forEach(\n              (relationTo) => {\n                const isRelatedToCustomNumberID = payload.collections[\n                  relationTo\n                ]?.config?.fields.find((relatedField) => {\n                  return (\n                    fieldAffectsData(relatedField) &&\n                    relatedField.name === 'id' &&\n                    relatedField.type === 'number'\n                  )\n                })\n\n                if (isRelatedToCustomNumberID) {\n                  if (isRelatedToCustomNumberID.type === 'number') hasNumberIDRelation = true\n                }\n              },\n            )\n\n            if (hasNumberIDRelation)\n              result.value[multiIDCondition].push({\n                [path]: { [operatorKey]: parseFloat(formattedValue) },\n              })\n          }\n        }\n\n        if (result.value[multiIDCondition].length > 1) {\n          return result\n        }\n      }\n\n      if (formattedOperator === 'like' && typeof formattedValue === 'string') {\n        const words = formattedValue.split(' ')\n\n        const result = {\n          value: {\n            $and: words.map((word) => ({\n              [path]: {\n                $options: 'i',\n                $regex: word.replace(/[\\\\^$*+?.()|[\\]{}]/g, '\\\\$&'),\n              },\n            })),\n          },\n        }\n\n        return result\n      }\n\n      // Some operators like 'near' need to define a full query\n      // so if there is no operator key, just return the value\n      if (!operatorKey) {\n        return {\n          path,\n          value: formattedValue,\n        }\n      }\n\n      return {\n        path,\n        value: { [operatorKey]: formattedValue },\n      }\n    }\n  }\n  return undefined\n}\n"],"names":["buildSearchParam","ObjectId","ObjectIdImport","subQueryOptions","lean","limit","collectionSlug","fields","globalSlug","incomingPath","locale","operator","payload","val","sanitizedPath","replace","paths","hasCustomID","customIDfield","collections","config","find","field","fieldAffectsData","name","idFieldType","type","push","complete","path","getLocalizedPaths","formattedOperator","rawQuery","formattedValue","sanitizeQueryValue","value","length","pathsToQuery","slice","reverse","initialRelationshipQuery","relationshipQuery","reduce","priorQuery","slug","subPath","i","priorQueryResult","SubModel","db","subQuery","buildQuery","where","result","$in","forEach","doc","stringID","_id","toString","mongoose","Types","isValid","nextSubPath","map","Promise","resolve","validOperators","includes","operatorKey","operatorMap","hasNumberIDRelation","multiIDCondition","Array","isArray","relationTo","isRelatedToCustomNumberID","relatedField","parseFloat","words","split","$and","word","$options","$regex","undefined"],"rangeMappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;","mappings":"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"}
@@ -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;AA8CD,eAAO,MAAM,kBAAkB,iDAM5B,sBAAsB;eACZ,MAAM;eACN,OAAO;UACZ,OAAO;CA8Jd,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;AAsED,eAAO,MAAM,kBAAkB,iDAM5B,sBAAsB;eACZ,MAAM;eACN,OAAO;UACZ,OAAO;CA4Kd,CAAA"}
@@ -70,6 +70,53 @@ const handleNonHasManyValues = (formattedValue, operator, path)=>{
70
70
  };
71
71
  }
72
72
  };
73
+ const buildExistsQuery = (formattedValue, path)=>{
74
+ if (formattedValue) {
75
+ return {
76
+ rawQuery: {
77
+ $and: [
78
+ {
79
+ [path]: {
80
+ $exists: true
81
+ }
82
+ },
83
+ {
84
+ [path]: {
85
+ $ne: null
86
+ }
87
+ },
88
+ {
89
+ [path]: {
90
+ $ne: ''
91
+ }
92
+ }
93
+ ]
94
+ }
95
+ };
96
+ } else {
97
+ return {
98
+ rawQuery: {
99
+ $or: [
100
+ {
101
+ [path]: {
102
+ $exists: false
103
+ }
104
+ },
105
+ {
106
+ [path]: {
107
+ $eq: null
108
+ }
109
+ },
110
+ {
111
+ [path]: {
112
+ $eq: ''
113
+ }
114
+ }
115
+ ]
116
+ }
117
+ };
118
+ }
119
+ };
73
120
  const sanitizeQueryValue = ({ field, hasCustomID, operator, path, val })=>{
74
121
  let formattedValue = val;
75
122
  let formattedOperator = operator;
@@ -109,8 +156,14 @@ const sanitizeQueryValue = ({ field, hasCustomID, operator, path, val })=>{
109
156
  formattedValue = formattedValue.map((arrayVal)=>parseFloat(arrayVal));
110
157
  }
111
158
  }
112
- if (field.type === 'number' && typeof formattedValue === 'string') {
113
- formattedValue = Number(val);
159
+ if (field.type === 'number') {
160
+ if (typeof formattedValue === 'string' && operator !== 'exists') {
161
+ formattedValue = Number(val);
162
+ }
163
+ if (operator === 'exists') {
164
+ formattedValue = val === 'true' ? true : val === 'false' ? false : Boolean(val);
165
+ return buildExistsQuery(formattedValue, path);
166
+ }
114
167
  }
115
168
  if (field.type === 'date' && typeof val === 'string' && operator !== 'exists') {
116
169
  formattedValue = new Date(val);
@@ -198,6 +251,10 @@ const sanitizeQueryValue = ({ field, hasCustomID, operator, path, val })=>{
198
251
  $regex: formattedValue.replace(/[\\^$*+?.()|[\]{}]/g, '\\$&')
199
252
  };
200
253
  }
254
+ if (operator === 'exists') {
255
+ formattedValue = formattedValue === 'true' || formattedValue === true;
256
+ return buildExistsQuery(formattedValue, path);
257
+ }
201
258
  }
202
259
  if ((path === '_id' || path === 'parent') && operator === 'like' && formattedValue.length === 24 && !hasCustomID) {
203
260
  formattedOperator = 'equals';
@@ -253,4 +310,4 @@ const sanitizeQueryValue = ({ field, hasCustomID, operator, path, val })=>{
253
310
  };
254
311
  };
255
312
 
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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"}
313
+ //# 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\nconst buildExistsQuery = (formattedValue, path) => {\n  if (formattedValue) {\n    return {\n      rawQuery: {\n        $and: [\n          { [path]: { $exists: true } },\n          { [path]: { $ne: null } },\n          { [path]: { $ne: '' } }, // Exclude null and empty string\n        ],\n      },\n    }\n  } else {\n    return {\n      rawQuery: {\n        $or: [\n          { [path]: { $exists: false } },\n          { [path]: { $eq: null } },\n          { [path]: { $eq: '' } }, // Treat empty string as null / undefined\n        ],\n      },\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') {\n    if (typeof formattedValue === 'string' && operator !== 'exists') {\n      formattedValue = Number(val)\n    }\n\n    if (operator === 'exists') {\n      formattedValue = val === 'true' ? true : val === 'false' ? false : Boolean(val)\n\n      return buildExistsQuery(formattedValue, path)\n    }\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    if (operator === 'exists') {\n      formattedValue = formattedValue === 'true' || formattedValue === true\n\n      return buildExistsQuery(formattedValue, path)\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","buildExistsQuery","$exists","$ne","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"],"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.7.1",
3
+ "version": "1.7.3",
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.25.0"
35
+ "payload": "2.30.1"
36
36
  },
37
37
  "peerDependencies": {
38
38
  "payload": "^2.0.0"