@payloadcms/db-postgres 0.1.7 → 0.1.9

Sign up to get free protection for your applications and to get access to all the features.
@@ -1 +1 @@
1
- {"version":3,"file":"findMany.d.ts","sourceRoot":"","sources":["../../src/find/findMany.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,QAAQ,EAAE,MAAM,kBAAkB,CAAA;AAChD,OAAO,KAAK,EAAE,KAAK,EAA8B,MAAM,eAAe,CAAA;AAItE,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,UAAU,CAAA;AAQ/C,KAAK,IAAI,GAAG,IAAI,CAAC,QAAQ,EAAE,YAAY,CAAC,GAAG;IACzC,OAAO,EAAE,eAAe,CAAA;IACxB,MAAM,EAAE,KAAK,EAAE,CAAA;IACf,SAAS,EAAE,MAAM,CAAA;CAClB,CAAA;AAED,eAAO,MAAM,QAAQ,iHAYlB,IAAI;;;;;;;;;;;EA0KN,CAAA"}
1
+ {"version":3,"file":"findMany.d.ts","sourceRoot":"","sources":["../../src/find/findMany.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,QAAQ,EAAE,MAAM,kBAAkB,CAAA;AAChD,OAAO,KAAK,EAAE,KAAK,EAA8B,MAAM,eAAe,CAAA;AAItE,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,UAAU,CAAA;AAQ/C,KAAK,IAAI,GAAG,IAAI,CAAC,QAAQ,EAAE,YAAY,CAAC,GAAG;IACzC,OAAO,EAAE,eAAe,CAAA;IACxB,MAAM,EAAE,KAAK,EAAE,CAAA;IACf,SAAS,EAAE,MAAM,CAAA;CAClB,CAAA;AAED,eAAO,MAAM,QAAQ,iHAYlB,IAAI;;;;;;;;;;;EA8KN,CAAA"}
@@ -21,7 +21,7 @@ function _interop_require_default(obj) {
21
21
  const findMany = async function find({ adapter, fields, limit: limitArg, locale, page = 1, pagination, req = {}, skip, sort, tableName, where: whereArg }) {
22
22
  const db = adapter.sessions[req.transactionID]?.db || adapter.drizzle;
23
23
  const table = adapter.tables[tableName];
24
- let limit = limitArg;
24
+ let limit = limitArg ?? 10;
25
25
  let totalDocs;
26
26
  let totalPages;
27
27
  let hasPrevPage;
@@ -119,7 +119,8 @@ const findMany = async function find({ adapter, fields, limit: limitArg, locale,
119
119
  findManyArgs.where = (0, _drizzleorm.inArray)(adapter.tables[tableName].id, Object.keys(orderedIDMap));
120
120
  } else {
121
121
  findManyArgs.limit = limitArg === 0 ? undefined : limitArg;
122
- findManyArgs.offset = skip || (page - 1) * limitArg;
122
+ const offset = skip || (page - 1) * limitArg;
123
+ if (!Number.isNaN(offset)) findManyArgs.offset = offset;
123
124
  if (where) {
124
125
  findManyArgs.where = where;
125
126
  }
@@ -195,4 +196,4 @@ const findMany = async function find({ adapter, fields, limit: limitArg, locale,
195
196
  };
196
197
  };
197
198
 
198
- //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../src/find/findMany.ts"],"sourcesContent":["import type { FindArgs } from 'payload/database'\nimport type { Field, PayloadRequest, TypeWithID } from 'payload/types'\n\nimport { inArray, sql } from 'drizzle-orm'\n\nimport type { PostgresAdapter } from '../types'\nimport type { ChainedMethods } from './chainMethods'\n\nimport buildQuery from '../queries/buildQuery'\nimport { transform } from '../transform/read'\nimport { buildFindManyArgs } from './buildFindManyArgs'\nimport { chainMethods } from './chainMethods'\n\ntype Args = Omit<FindArgs, 'collection'> & {\n  adapter: PostgresAdapter\n  fields: Field[]\n  tableName: string\n}\n\nexport const findMany = async function find({\n  adapter,\n  fields,\n  limit: limitArg,\n  locale,\n  page = 1,\n  pagination,\n  req = {} as PayloadRequest,\n  skip,\n  sort,\n  tableName,\n  where: whereArg,\n}: Args) {\n  const db = adapter.sessions[req.transactionID]?.db || adapter.drizzle\n  const table = adapter.tables[tableName]\n\n  let limit = limitArg\n  let totalDocs: number\n  let totalPages: number\n  let hasPrevPage: boolean\n  let hasNextPage: boolean\n  let pagingCounter: number\n  let selectDistinctResult\n\n  const { joinAliases, joins, orderBy, selectFields, where } = await buildQuery({\n    adapter,\n    fields,\n    locale,\n    sort,\n    tableName,\n    where: whereArg,\n  })\n\n  const orderedIDMap: Record<number | string, number> = {}\n\n  const selectDistinctMethods: ChainedMethods = []\n\n  if (orderBy?.order && orderBy?.column) {\n    selectDistinctMethods.push({\n      args: [orderBy.order(orderBy.column)],\n      method: 'orderBy',\n    })\n  }\n\n  const findManyArgs = buildFindManyArgs({\n    adapter,\n    depth: 0,\n    fields,\n    tableName,\n  })\n\n  // only fetch IDs when a sort or where query is used that needs to be done on join tables, otherwise these can be done directly on the table in findMany\n  if (Object.keys(joins).length > 0 || joinAliases.length > 0) {\n    if (where) {\n      selectDistinctMethods.push({ args: [where], method: 'where' })\n    }\n\n    joinAliases.forEach(({ condition, table }) => {\n      selectDistinctMethods.push({\n        args: [table, condition],\n        method: 'leftJoin',\n      })\n    })\n\n    Object.entries(joins).forEach(([joinTable, condition]) => {\n      if (joinTable) {\n        selectDistinctMethods.push({\n          args: [adapter.tables[joinTable], condition],\n          method: 'leftJoin',\n        })\n      }\n    })\n\n    selectDistinctMethods.push({ args: [skip || (page - 1) * limit], method: 'offset' })\n    selectDistinctMethods.push({ args: [limit === 0 ? undefined : limit], method: 'limit' })\n\n    selectDistinctResult = await chainMethods({\n      methods: selectDistinctMethods,\n      query: db.selectDistinct(selectFields).from(table),\n    })\n\n    if (selectDistinctResult.length === 0) {\n      return {\n        docs: [],\n        hasNextPage: false,\n        hasPrevPage: false,\n        limit,\n        nextPage: null,\n        page: 1,\n        pagingCounter: 0,\n        prevPage: null,\n        totalDocs: 0,\n        totalPages: 0,\n      }\n    }\n    // set the id in an object for sorting later\n    selectDistinctResult.forEach(({ id }, i) => {\n      orderedIDMap[id as number | string] = i\n    })\n    findManyArgs.where = inArray(adapter.tables[tableName].id, Object.keys(orderedIDMap))\n  } else {\n    findManyArgs.limit = limitArg === 0 ? undefined : limitArg\n    findManyArgs.offset = skip || (page - 1) * limitArg\n    if (where) {\n      findManyArgs.where = where\n    }\n    findManyArgs.orderBy = orderBy.order(orderBy.column)\n  }\n\n  const findPromise = db.query[tableName].findMany(findManyArgs)\n\n  if (pagination !== false || selectDistinctResult?.length > limit) {\n    const selectCountMethods: ChainedMethods = []\n\n    joinAliases.forEach(({ condition, table }) => {\n      selectCountMethods.push({\n        args: [table, condition],\n        method: 'leftJoin',\n      })\n    })\n\n    Object.entries(joins).forEach(([joinTable, condition]) => {\n      if (joinTable) {\n        selectCountMethods.push({\n          args: [adapter.tables[joinTable], condition],\n          method: 'leftJoin',\n        })\n      }\n    })\n\n    const countResult = await chainMethods({\n      methods: selectCountMethods,\n      query: db\n        .select({\n          count: sql<number>`count\n              (*)`,\n        })\n        .from(table)\n        .where(where),\n    })\n    totalDocs = Number(countResult[0].count)\n    totalPages = typeof limit === 'number' ? Math.ceil(totalDocs / limit) : 1\n    hasPrevPage = page > 1\n    hasNextPage = totalPages > page\n    pagingCounter = (page - 1) * limit + 1\n  }\n\n  const rawDocs = await findPromise\n  // sort rawDocs from selectQuery\n  if (Object.keys(orderedIDMap).length > 0) {\n    rawDocs.sort((a, b) => orderedIDMap[a.id] - orderedIDMap[b.id])\n  }\n\n  if (pagination === false) {\n    totalDocs = rawDocs.length\n    limit = totalDocs\n    totalPages = 1\n    pagingCounter = 1\n    hasPrevPage = false\n    hasNextPage = false\n  }\n\n  const docs = rawDocs.map((data: TypeWithID) => {\n    return transform({\n      config: adapter.payload.config,\n      data,\n      fields,\n    })\n  })\n\n  return {\n    docs,\n    hasNextPage,\n    hasPrevPage,\n    limit,\n    nextPage: hasNextPage ? page + 1 : null,\n    page,\n    pagingCounter,\n    prevPage: hasPrevPage ? page - 1 : null,\n    totalDocs,\n    totalPages,\n  }\n}\n"],"names":["findMany","find","adapter","fields","limit","limitArg","locale","page","pagination","req","skip","sort","tableName","where","whereArg","db","sessions","transactionID","drizzle","table","tables","totalDocs","totalPages","hasPrevPage","hasNextPage","pagingCounter","selectDistinctResult","joinAliases","joins","orderBy","selectFields","buildQuery","orderedIDMap","selectDistinctMethods","order","column","push","args","method","findManyArgs","buildFindManyArgs","depth","Object","keys","length","forEach","condition","entries","joinTable","undefined","chainMethods","methods","query","selectDistinct","from","docs","nextPage","prevPage","id","i","inArray","offset","findPromise","selectCountMethods","countResult","select","count","sql","Number","Math","ceil","rawDocs","a","b","map","data","transform","config","payload"],"mappings":"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"}
199
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../src/find/findMany.ts"],"sourcesContent":["import type { FindArgs } from 'payload/database'\nimport type { Field, PayloadRequest, TypeWithID } from 'payload/types'\n\nimport { inArray, sql } from 'drizzle-orm'\n\nimport type { PostgresAdapter } from '../types'\nimport type { ChainedMethods } from './chainMethods'\n\nimport buildQuery from '../queries/buildQuery'\nimport { transform } from '../transform/read'\nimport { buildFindManyArgs } from './buildFindManyArgs'\nimport { chainMethods } from './chainMethods'\n\ntype Args = Omit<FindArgs, 'collection'> & {\n  adapter: PostgresAdapter\n  fields: Field[]\n  tableName: string\n}\n\nexport const findMany = async function find({\n  adapter,\n  fields,\n  limit: limitArg,\n  locale,\n  page = 1,\n  pagination,\n  req = {} as PayloadRequest,\n  skip,\n  sort,\n  tableName,\n  where: whereArg,\n}: Args) {\n  const db = adapter.sessions[req.transactionID]?.db || adapter.drizzle\n  const table = adapter.tables[tableName]\n\n  let limit = limitArg ?? 10\n  let totalDocs: number\n  let totalPages: number\n  let hasPrevPage: boolean\n  let hasNextPage: boolean\n  let pagingCounter: number\n  let selectDistinctResult\n\n  const { joinAliases, joins, orderBy, selectFields, where } = await buildQuery({\n    adapter,\n    fields,\n    locale,\n    sort,\n    tableName,\n    where: whereArg,\n  })\n\n  const orderedIDMap: Record<number | string, number> = {}\n\n  const selectDistinctMethods: ChainedMethods = []\n\n  if (orderBy?.order && orderBy?.column) {\n    selectDistinctMethods.push({\n      args: [orderBy.order(orderBy.column)],\n      method: 'orderBy',\n    })\n  }\n\n  const findManyArgs = buildFindManyArgs({\n    adapter,\n    depth: 0,\n    fields,\n    tableName,\n  })\n\n  // only fetch IDs when a sort or where query is used that needs to be done on join tables, otherwise these can be done directly on the table in findMany\n  if (Object.keys(joins).length > 0 || joinAliases.length > 0) {\n    if (where) {\n      selectDistinctMethods.push({ args: [where], method: 'where' })\n    }\n\n    joinAliases.forEach(({ condition, table }) => {\n      selectDistinctMethods.push({\n        args: [table, condition],\n        method: 'leftJoin',\n      })\n    })\n\n    Object.entries(joins).forEach(([joinTable, condition]) => {\n      if (joinTable) {\n        selectDistinctMethods.push({\n          args: [adapter.tables[joinTable], condition],\n          method: 'leftJoin',\n        })\n      }\n    })\n\n    selectDistinctMethods.push({ args: [skip || (page - 1) * limit], method: 'offset' })\n    selectDistinctMethods.push({ args: [limit === 0 ? undefined : limit], method: 'limit' })\n\n    selectDistinctResult = await chainMethods({\n      methods: selectDistinctMethods,\n      query: db.selectDistinct(selectFields).from(table),\n    })\n\n    if (selectDistinctResult.length === 0) {\n      return {\n        docs: [],\n        hasNextPage: false,\n        hasPrevPage: false,\n        limit,\n        nextPage: null,\n        page: 1,\n        pagingCounter: 0,\n        prevPage: null,\n        totalDocs: 0,\n        totalPages: 0,\n      }\n    }\n    // set the id in an object for sorting later\n    selectDistinctResult.forEach(({ id }, i) => {\n      orderedIDMap[id as number | string] = i\n    })\n    findManyArgs.where = inArray(adapter.tables[tableName].id, Object.keys(orderedIDMap))\n  } else {\n    findManyArgs.limit = limitArg === 0 ? undefined : limitArg\n\n    const offset = skip || (page - 1) * limitArg\n\n    if (!Number.isNaN(offset)) findManyArgs.offset = offset\n\n    if (where) {\n      findManyArgs.where = where\n    }\n    findManyArgs.orderBy = orderBy.order(orderBy.column)\n  }\n\n  const findPromise = db.query[tableName].findMany(findManyArgs)\n\n  if (pagination !== false || selectDistinctResult?.length > limit) {\n    const selectCountMethods: ChainedMethods = []\n\n    joinAliases.forEach(({ condition, table }) => {\n      selectCountMethods.push({\n        args: [table, condition],\n        method: 'leftJoin',\n      })\n    })\n\n    Object.entries(joins).forEach(([joinTable, condition]) => {\n      if (joinTable) {\n        selectCountMethods.push({\n          args: [adapter.tables[joinTable], condition],\n          method: 'leftJoin',\n        })\n      }\n    })\n\n    const countResult = await chainMethods({\n      methods: selectCountMethods,\n      query: db\n        .select({\n          count: sql<number>`count\n              (*)`,\n        })\n        .from(table)\n        .where(where),\n    })\n    totalDocs = Number(countResult[0].count)\n    totalPages = typeof limit === 'number' ? Math.ceil(totalDocs / limit) : 1\n    hasPrevPage = page > 1\n    hasNextPage = totalPages > page\n    pagingCounter = (page - 1) * limit + 1\n  }\n\n  const rawDocs = await findPromise\n  // sort rawDocs from selectQuery\n  if (Object.keys(orderedIDMap).length > 0) {\n    rawDocs.sort((a, b) => orderedIDMap[a.id] - orderedIDMap[b.id])\n  }\n\n  if (pagination === false) {\n    totalDocs = rawDocs.length\n    limit = totalDocs\n    totalPages = 1\n    pagingCounter = 1\n    hasPrevPage = false\n    hasNextPage = false\n  }\n\n  const docs = rawDocs.map((data: TypeWithID) => {\n    return transform({\n      config: adapter.payload.config,\n      data,\n      fields,\n    })\n  })\n\n  return {\n    docs,\n    hasNextPage,\n    hasPrevPage,\n    limit,\n    nextPage: hasNextPage ? page + 1 : null,\n    page,\n    pagingCounter,\n    prevPage: hasPrevPage ? page - 1 : null,\n    totalDocs,\n    totalPages,\n  }\n}\n"],"names":["findMany","find","adapter","fields","limit","limitArg","locale","page","pagination","req","skip","sort","tableName","where","whereArg","db","sessions","transactionID","drizzle","table","tables","totalDocs","totalPages","hasPrevPage","hasNextPage","pagingCounter","selectDistinctResult","joinAliases","joins","orderBy","selectFields","buildQuery","orderedIDMap","selectDistinctMethods","order","column","push","args","method","findManyArgs","buildFindManyArgs","depth","Object","keys","length","forEach","condition","entries","joinTable","undefined","chainMethods","methods","query","selectDistinct","from","docs","nextPage","prevPage","id","i","inArray","offset","Number","isNaN","findPromise","selectCountMethods","countResult","select","count","sql","Math","ceil","rawDocs","a","b","map","data","transform","config","payload"],"mappings":";;;;+BAmBaA;;;eAAAA;;;4BAhBgB;mEAKN;sBACG;mCACQ;8BACL;;;;;;AAQtB,MAAMA,WAAW,eAAeC,KAAK,EAC1CC,OAAO,EACPC,MAAM,EACNC,OAAOC,QAAQ,EACfC,MAAM,EACNC,OAAO,CAAC,EACRC,UAAU,EACVC,MAAM,CAAC,CAAmB,EAC1BC,IAAI,EACJC,IAAI,EACJC,SAAS,EACTC,OAAOC,QAAQ,EACV;IACL,MAAMC,KAAKb,QAAQc,QAAQ,CAACP,IAAIQ,aAAa,CAAC,EAAEF,MAAMb,QAAQgB,OAAO;IACrE,MAAMC,QAAQjB,QAAQkB,MAAM,CAACR,UAAU;IAEvC,IAAIR,QAAQC,YAAY;IACxB,IAAIgB;IACJ,IAAIC;IACJ,IAAIC;IACJ,IAAIC;IACJ,IAAIC;IACJ,IAAIC;IAEJ,MAAM,EAAEC,WAAW,EAAEC,KAAK,EAAEC,OAAO,EAAEC,YAAY,EAAEjB,KAAK,EAAE,GAAG,MAAMkB,IAAAA,mBAAU,EAAC;QAC5E7B;QACAC;QACAG;QACAK;QACAC;QACAC,OAAOC;IACT;IAEA,MAAMkB,eAAgD,CAAC;IAEvD,MAAMC,wBAAwC,EAAE;IAEhD,IAAIJ,SAASK,SAASL,SAASM,QAAQ;QACrCF,sBAAsBG,IAAI,CAAC;YACzBC,MAAM;gBAACR,QAAQK,KAAK,CAACL,QAAQM,MAAM;aAAE;YACrCG,QAAQ;QACV;IACF;IAEA,MAAMC,eAAeC,IAAAA,oCAAiB,EAAC;QACrCtC;QACAuC,OAAO;QACPtC;QACAS;IACF;IAEA,wJAAwJ;IACxJ,IAAI8B,OAAOC,IAAI,CAACf,OAAOgB,MAAM,GAAG,KAAKjB,YAAYiB,MAAM,GAAG,GAAG;QAC3D,IAAI/B,OAAO;YACToB,sBAAsBG,IAAI,CAAC;gBAAEC,MAAM;oBAACxB;iBAAM;gBAAEyB,QAAQ;YAAQ;QAC9D;QAEAX,YAAYkB,OAAO,CAAC,CAAC,EAAEC,SAAS,EAAE3B,KAAK,EAAE;YACvCc,sBAAsBG,IAAI,CAAC;gBACzBC,MAAM;oBAAClB;oBAAO2B;iBAAU;gBACxBR,QAAQ;YACV;QACF;QAEAI,OAAOK,OAAO,CAACnB,OAAOiB,OAAO,CAAC,CAAC,CAACG,WAAWF,UAAU;YACnD,IAAIE,WAAW;gBACbf,sBAAsBG,IAAI,CAAC;oBACzBC,MAAM;wBAACnC,QAAQkB,MAAM,CAAC4B,UAAU;wBAAEF;qBAAU;oBAC5CR,QAAQ;gBACV;YACF;QACF;QAEAL,sBAAsBG,IAAI,CAAC;YAAEC,MAAM;gBAAC3B,QAAQ,AAACH,CAAAA,OAAO,CAAA,IAAKH;aAAM;YAAEkC,QAAQ;QAAS;QAClFL,sBAAsBG,IAAI,CAAC;YAAEC,MAAM;gBAACjC,UAAU,IAAI6C,YAAY7C;aAAM;YAAEkC,QAAQ;QAAQ;QAEtFZ,uBAAuB,MAAMwB,IAAAA,0BAAY,EAAC;YACxCC,SAASlB;YACTmB,OAAOrC,GAAGsC,cAAc,CAACvB,cAAcwB,IAAI,CAACnC;QAC9C;QAEA,IAAIO,qBAAqBkB,MAAM,KAAK,GAAG;YACrC,OAAO;gBACLW,MAAM,EAAE;gBACR/B,aAAa;gBACbD,aAAa;gBACbnB;gBACAoD,UAAU;gBACVjD,MAAM;gBACNkB,eAAe;gBACfgC,UAAU;gBACVpC,WAAW;gBACXC,YAAY;YACd;QACF;QACA,4CAA4C;QAC5CI,qBAAqBmB,OAAO,CAAC,CAAC,EAAEa,EAAE,EAAE,EAAEC;YACpC3B,YAAY,CAAC0B,GAAsB,GAAGC;QACxC;QACApB,aAAa1B,KAAK,GAAG+C,IAAAA,mBAAO,EAAC1D,QAAQkB,MAAM,CAACR,UAAU,CAAC8C,EAAE,EAAEhB,OAAOC,IAAI,CAACX;IACzE,OAAO;QACLO,aAAanC,KAAK,GAAGC,aAAa,IAAI4C,YAAY5C;QAElD,MAAMwD,SAASnD,QAAQ,AAACH,CAAAA,OAAO,CAAA,IAAKF;QAEpC,IAAI,CAACyD,OAAOC,KAAK,CAACF,SAAStB,aAAasB,MAAM,GAAGA;QAEjD,IAAIhD,OAAO;YACT0B,aAAa1B,KAAK,GAAGA;QACvB;QACA0B,aAAaV,OAAO,GAAGA,QAAQK,KAAK,CAACL,QAAQM,MAAM;IACrD;IAEA,MAAM6B,cAAcjD,GAAGqC,KAAK,CAACxC,UAAU,CAACZ,QAAQ,CAACuC;IAEjD,IAAI/B,eAAe,SAASkB,sBAAsBkB,SAASxC,OAAO;QAChE,MAAM6D,qBAAqC,EAAE;QAE7CtC,YAAYkB,OAAO,CAAC,CAAC,EAAEC,SAAS,EAAE3B,KAAK,EAAE;YACvC8C,mBAAmB7B,IAAI,CAAC;gBACtBC,MAAM;oBAAClB;oBAAO2B;iBAAU;gBACxBR,QAAQ;YACV;QACF;QAEAI,OAAOK,OAAO,CAACnB,OAAOiB,OAAO,CAAC,CAAC,CAACG,WAAWF,UAAU;YACnD,IAAIE,WAAW;gBACbiB,mBAAmB7B,IAAI,CAAC;oBACtBC,MAAM;wBAACnC,QAAQkB,MAAM,CAAC4B,UAAU;wBAAEF;qBAAU;oBAC5CR,QAAQ;gBACV;YACF;QACF;QAEA,MAAM4B,cAAc,MAAMhB,IAAAA,0BAAY,EAAC;YACrCC,SAASc;YACTb,OAAOrC,GACJoD,MAAM,CAAC;gBACNC,OAAOC,IAAAA,eAAG,CAAQ,CAAC;iBACZ,CAAC;YACV,GACCf,IAAI,CAACnC,OACLN,KAAK,CAACA;QACX;QACAQ,YAAYyC,OAAOI,WAAW,CAAC,EAAE,CAACE,KAAK;QACvC9C,aAAa,OAAOlB,UAAU,WAAWkE,KAAKC,IAAI,CAAClD,YAAYjB,SAAS;QACxEmB,cAAchB,OAAO;QACrBiB,cAAcF,aAAaf;QAC3BkB,gBAAgB,AAAClB,CAAAA,OAAO,CAAA,IAAKH,QAAQ;IACvC;IAEA,MAAMoE,UAAU,MAAMR;IACtB,gCAAgC;IAChC,IAAItB,OAAOC,IAAI,CAACX,cAAcY,MAAM,GAAG,GAAG;QACxC4B,QAAQ7D,IAAI,CAAC,CAAC8D,GAAGC,IAAM1C,YAAY,CAACyC,EAAEf,EAAE,CAAC,GAAG1B,YAAY,CAAC0C,EAAEhB,EAAE,CAAC;IAChE;IAEA,IAAIlD,eAAe,OAAO;QACxBa,YAAYmD,QAAQ5B,MAAM;QAC1BxC,QAAQiB;QACRC,aAAa;QACbG,gBAAgB;QAChBF,cAAc;QACdC,cAAc;IAChB;IAEA,MAAM+B,OAAOiB,QAAQG,GAAG,CAAC,CAACC;QACxB,OAAOC,IAAAA,eAAS,EAAC;YACfC,QAAQ5E,QAAQ6E,OAAO,CAACD,MAAM;YAC9BF;YACAzE;QACF;IACF;IAEA,OAAO;QACLoD;QACA/B;QACAD;QACAnB;QACAoD,UAAUhC,cAAcjB,OAAO,IAAI;QACnCA;QACAkB;QACAgC,UAAUlC,cAAchB,OAAO,IAAI;QACnCc;QACAC;IACF;AACF"}
@@ -116,7 +116,7 @@ const traverseFields = ({ _locales, adapter, currentArgs, currentTableName, dept
116
116
  currentTableName,
117
117
  depth,
118
118
  fields: block.fields,
119
- path,
119
+ path: '',
120
120
  topLevelArgs,
121
121
  topLevelTableName
122
122
  });
@@ -146,4 +146,4 @@ const traverseFields = ({ _locales, adapter, currentArgs, currentTableName, dept
146
146
  return topLevelArgs;
147
147
  };
148
148
 
149
- //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../src/find/traverseFields.ts"],"sourcesContent":["/* eslint-disable no-param-reassign */\nimport type { Field } from 'payload/types'\n\nimport { fieldAffectsData, tabHasName } from 'payload/types'\nimport toSnakeCase from 'to-snake-case'\n\nimport type { PostgresAdapter } from '../types'\nimport type { Result } from './buildFindManyArgs'\n\ntype TraverseFieldArgs = {\n  _locales: Record<string, unknown>\n  adapter: PostgresAdapter\n  currentArgs: Record<string, unknown>\n  currentTableName: string\n  depth?: number\n  fields: Field[]\n  path: string\n  topLevelArgs: Record<string, unknown>\n  topLevelTableName: string\n}\n\nexport const traverseFields = ({\n  _locales,\n  adapter,\n  currentArgs,\n  currentTableName,\n  depth,\n  fields,\n  path,\n  topLevelArgs,\n  topLevelTableName,\n}: TraverseFieldArgs) => {\n  fields.forEach((field) => {\n    if (field.type === 'collapsible' || field.type === 'row') {\n      traverseFields({\n        _locales,\n        adapter,\n        currentArgs,\n        currentTableName,\n        depth,\n        fields: field.fields,\n        path,\n        topLevelArgs,\n        topLevelTableName,\n      })\n\n      return\n    }\n\n    if (field.type === 'tabs') {\n      field.tabs.forEach((tab) => {\n        const tabPath = tabHasName(tab) ? `${path}${tab.name}_` : path\n\n        traverseFields({\n          _locales,\n          adapter,\n          currentArgs,\n          currentTableName,\n          depth,\n          fields: tab.fields,\n          path: tabPath,\n          topLevelArgs,\n          topLevelTableName,\n        })\n      })\n\n      return\n    }\n\n    if (fieldAffectsData(field)) {\n      switch (field.type) {\n        case 'array': {\n          const withArray: Result = {\n            columns: {\n              _parentID: false,\n            },\n            orderBy: ({ _order }, { asc }) => [asc(_order)],\n            with: {},\n          }\n\n          const arrayTableName = `${currentTableName}_${toSnakeCase(field.name)}`\n\n          if (adapter.tables[`${arrayTableName}_locales`]) withArray.with._locales = _locales\n          currentArgs.with[`${path}${field.name}`] = withArray\n\n          traverseFields({\n            _locales,\n            adapter,\n            currentArgs: withArray,\n            currentTableName: arrayTableName,\n            depth,\n            fields: field.fields,\n            path: '',\n            topLevelArgs,\n            topLevelTableName,\n          })\n\n          break\n        }\n\n        case 'select': {\n          if (field.hasMany) {\n            const withSelect: Result = {\n              columns: {\n                id: false,\n                order: false,\n                parent: false,\n              },\n              orderBy: ({ order }, { asc }) => [asc(order)],\n            }\n\n            currentArgs.with[`${path}${field.name}`] = withSelect\n          }\n\n          break\n        }\n\n        case 'blocks':\n          field.blocks.forEach((block) => {\n            const blockKey = `_blocks_${block.slug}`\n\n            if (!topLevelArgs[blockKey]) {\n              const withBlock: Result = {\n                columns: {\n                  _parentID: false,\n                },\n                orderBy: ({ _order }, { asc }) => [asc(_order)],\n                with: {},\n              }\n\n              if (adapter.tables[`${topLevelTableName}_${toSnakeCase(block.slug)}_locales`])\n                withBlock.with._locales = _locales\n              topLevelArgs.with[blockKey] = withBlock\n\n              traverseFields({\n                _locales,\n                adapter,\n                currentArgs: withBlock,\n                currentTableName,\n                depth,\n                fields: block.fields,\n                path,\n                topLevelArgs,\n                topLevelTableName,\n              })\n            }\n          })\n\n          break\n\n        case 'group':\n          traverseFields({\n            _locales,\n            adapter,\n            currentArgs,\n            currentTableName,\n            depth,\n            fields: field.fields,\n            path: `${path}${field.name}_`,\n            topLevelArgs,\n            topLevelTableName,\n          })\n\n          break\n\n        default: {\n          break\n        }\n      }\n    }\n  })\n\n  return topLevelArgs\n}\n"],"names":["traverseFields","_locales","adapter","currentArgs","currentTableName","depth","fields","path","topLevelArgs","topLevelTableName","forEach","field","type","tabs","tab","tabPath","tabHasName","name","fieldAffectsData","withArray","columns","_parentID","orderBy","_order","asc","with","arrayTableName","toSnakeCase","tables","hasMany","withSelect","id","order","parent","blocks","block","blockKey","slug","withBlock"],"mappings":"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"}
149
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../src/find/traverseFields.ts"],"sourcesContent":["/* eslint-disable no-param-reassign */\nimport type { Field } from 'payload/types'\n\nimport { fieldAffectsData, tabHasName } from 'payload/types'\nimport toSnakeCase from 'to-snake-case'\n\nimport type { PostgresAdapter } from '../types'\nimport type { Result } from './buildFindManyArgs'\n\ntype TraverseFieldArgs = {\n  _locales: Record<string, unknown>\n  adapter: PostgresAdapter\n  currentArgs: Record<string, unknown>\n  currentTableName: string\n  depth?: number\n  fields: Field[]\n  path: string\n  topLevelArgs: Record<string, unknown>\n  topLevelTableName: string\n}\n\nexport const traverseFields = ({\n  _locales,\n  adapter,\n  currentArgs,\n  currentTableName,\n  depth,\n  fields,\n  path,\n  topLevelArgs,\n  topLevelTableName,\n}: TraverseFieldArgs) => {\n  fields.forEach((field) => {\n    if (field.type === 'collapsible' || field.type === 'row') {\n      traverseFields({\n        _locales,\n        adapter,\n        currentArgs,\n        currentTableName,\n        depth,\n        fields: field.fields,\n        path,\n        topLevelArgs,\n        topLevelTableName,\n      })\n\n      return\n    }\n\n    if (field.type === 'tabs') {\n      field.tabs.forEach((tab) => {\n        const tabPath = tabHasName(tab) ? `${path}${tab.name}_` : path\n\n        traverseFields({\n          _locales,\n          adapter,\n          currentArgs,\n          currentTableName,\n          depth,\n          fields: tab.fields,\n          path: tabPath,\n          topLevelArgs,\n          topLevelTableName,\n        })\n      })\n\n      return\n    }\n\n    if (fieldAffectsData(field)) {\n      switch (field.type) {\n        case 'array': {\n          const withArray: Result = {\n            columns: {\n              _parentID: false,\n            },\n            orderBy: ({ _order }, { asc }) => [asc(_order)],\n            with: {},\n          }\n\n          const arrayTableName = `${currentTableName}_${toSnakeCase(field.name)}`\n\n          if (adapter.tables[`${arrayTableName}_locales`]) withArray.with._locales = _locales\n          currentArgs.with[`${path}${field.name}`] = withArray\n\n          traverseFields({\n            _locales,\n            adapter,\n            currentArgs: withArray,\n            currentTableName: arrayTableName,\n            depth,\n            fields: field.fields,\n            path: '',\n            topLevelArgs,\n            topLevelTableName,\n          })\n\n          break\n        }\n\n        case 'select': {\n          if (field.hasMany) {\n            const withSelect: Result = {\n              columns: {\n                id: false,\n                order: false,\n                parent: false,\n              },\n              orderBy: ({ order }, { asc }) => [asc(order)],\n            }\n\n            currentArgs.with[`${path}${field.name}`] = withSelect\n          }\n\n          break\n        }\n\n        case 'blocks':\n          field.blocks.forEach((block) => {\n            const blockKey = `_blocks_${block.slug}`\n\n            if (!topLevelArgs[blockKey]) {\n              const withBlock: Result = {\n                columns: {\n                  _parentID: false,\n                },\n                orderBy: ({ _order }, { asc }) => [asc(_order)],\n                with: {},\n              }\n\n              if (adapter.tables[`${topLevelTableName}_${toSnakeCase(block.slug)}_locales`])\n                withBlock.with._locales = _locales\n              topLevelArgs.with[blockKey] = withBlock\n\n              traverseFields({\n                _locales,\n                adapter,\n                currentArgs: withBlock,\n                currentTableName,\n                depth,\n                fields: block.fields,\n                path: '',\n                topLevelArgs,\n                topLevelTableName,\n              })\n            }\n          })\n\n          break\n\n        case 'group':\n          traverseFields({\n            _locales,\n            adapter,\n            currentArgs,\n            currentTableName,\n            depth,\n            fields: field.fields,\n            path: `${path}${field.name}_`,\n            topLevelArgs,\n            topLevelTableName,\n          })\n\n          break\n\n        default: {\n          break\n        }\n      }\n    }\n  })\n\n  return topLevelArgs\n}\n"],"names":["traverseFields","_locales","adapter","currentArgs","currentTableName","depth","fields","path","topLevelArgs","topLevelTableName","forEach","field","type","tabs","tab","tabPath","tabHasName","name","fieldAffectsData","withArray","columns","_parentID","orderBy","_order","asc","with","arrayTableName","toSnakeCase","tables","hasMany","withSelect","id","order","parent","blocks","block","blockKey","slug","withBlock"],"mappings":"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"}
@@ -1 +1 @@
1
- {"version":3,"file":"parseParams.d.ts","sourceRoot":"","sources":["../../src/queries/parseParams.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,GAAG,EAAE,MAAM,aAAa,CAAA;AACtC,OAAO,KAAK,EAAE,KAAK,EAAY,KAAK,EAAE,MAAM,eAAe,CAAA;AAM3D,OAAO,KAAK,EAAE,aAAa,EAAE,eAAe,EAAE,MAAM,UAAU,CAAA;AAC9D,OAAO,KAAK,EAAE,qBAAqB,EAAE,eAAe,EAAE,MAAM,cAAc,CAAA;AAS1E,KAAK,IAAI,GAAG;IACV,OAAO,EAAE,eAAe,CAAA;IACxB,MAAM,EAAE,KAAK,EAAE,CAAA;IACf,WAAW,EAAE,qBAAqB,CAAA;IAClC,KAAK,EAAE,eAAe,CAAA;IACtB,MAAM,EAAE,MAAM,CAAA;IACd,YAAY,EAAE,MAAM,CAAC,MAAM,EAAE,aAAa,CAAC,CAAA;IAC3C,SAAS,EAAE,MAAM,CAAA;IACjB,KAAK,EAAE,KAAK,CAAA;CACb,CAAA;AAED,wBAAsB,WAAW,CAAC,EAChC,OAAO,EACP,MAAM,EACN,WAAW,EACX,KAAK,EACL,MAAM,EACN,YAAY,EACZ,SAAS,EACT,KAAK,GACN,EAAE,IAAI,GAAG,OAAO,CAAC,GAAG,CAAC,CAkKrB"}
1
+ {"version":3,"file":"parseParams.d.ts","sourceRoot":"","sources":["../../src/queries/parseParams.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,GAAG,EAAE,MAAM,aAAa,CAAA;AACtC,OAAO,KAAK,EAAE,KAAK,EAAY,KAAK,EAAE,MAAM,eAAe,CAAA;AAM3D,OAAO,KAAK,EAAE,aAAa,EAAE,eAAe,EAAE,MAAM,UAAU,CAAA;AAC9D,OAAO,KAAK,EAAE,qBAAqB,EAAE,eAAe,EAAE,MAAM,cAAc,CAAA;AAS1E,KAAK,IAAI,GAAG;IACV,OAAO,EAAE,eAAe,CAAA;IACxB,MAAM,EAAE,KAAK,EAAE,CAAA;IACf,WAAW,EAAE,qBAAqB,CAAA;IAClC,KAAK,EAAE,eAAe,CAAA;IACtB,MAAM,EAAE,MAAM,CAAA;IACd,YAAY,EAAE,MAAM,CAAC,MAAM,EAAE,aAAa,CAAC,CAAA;IAC3C,SAAS,EAAE,MAAM,CAAA;IACjB,KAAK,EAAE,KAAK,CAAA;CACb,CAAA;AAED,wBAAsB,WAAW,CAAC,EAChC,OAAO,EACP,MAAM,EACN,WAAW,EACX,KAAK,EACL,MAAM,EACN,YAAY,EACZ,SAAS,EACT,KAAK,GACN,EAAE,IAAI,GAAG,OAAO,CAAC,GAAG,CAAC,CA6KrB"}
@@ -117,22 +117,28 @@ async function parseParams({ adapter, fields, joinAliases, joins, locale, select
117
117
  constraints.push((0, _drizzleorm.and)(...val.split(' ').map((word)=>(0, _drizzleorm.ilike)(table[columnName], `%${word}%`))));
118
118
  break;
119
119
  }
120
- const { operator: queryOperator, value: queryValue } = (0, _sanitizeQueryValue.sanitizeQueryValue)({
120
+ const sanitizedQueryValue = (0, _sanitizeQueryValue.sanitizeQueryValue)({
121
121
  field,
122
122
  operator,
123
123
  relationOrPath,
124
124
  val
125
125
  });
126
+ if (sanitizedQueryValue === null) {
127
+ break;
128
+ }
129
+ const { operator: queryOperator, value: queryValue } = sanitizedQueryValue;
126
130
  if (queryOperator === 'not_equals' && queryValue !== null) {
127
131
  constraints.push((0, _drizzleorm.or)((0, _drizzleorm.isNull)(rawColumn || table[columnName]), /* eslint-disable @typescript-eslint/no-explicit-any */ (0, _drizzleorm.ne)(rawColumn || table[columnName], queryValue)));
128
- } else if ((field.type === 'relationship' || field.type === 'upload') && Array.isArray(queryValue) && operator === 'not_in') {
132
+ break;
133
+ }
134
+ if ((field.type === 'relationship' || field.type === 'upload') && Array.isArray(queryValue) && operator === 'not_in') {
129
135
  constraints.push((0, _drizzleorm.sql)`${(0, _drizzleorm.notInArray)(table[columnName], queryValue)} OR
130
136
  ${table[columnName]}
131
137
  IS
132
138
  NULL`);
133
- } else {
134
- constraints.push(_operatorMap.operatorMap[queryOperator](rawColumn || table[columnName], queryValue));
139
+ break;
135
140
  }
141
+ constraints.push(_operatorMap.operatorMap[queryOperator](rawColumn || table[columnName], queryValue));
136
142
  }
137
143
  }
138
144
  }
@@ -153,4 +159,4 @@ async function parseParams({ adapter, fields, joinAliases, joins, locale, select
153
159
  return result;
154
160
  }
155
161
 
156
- //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../src/queries/parseParams.ts"],"sourcesContent":["/* eslint-disable no-await-in-loop */\nimport type { SQL } from 'drizzle-orm'\nimport type { Field, Operator, Where } from 'payload/types'\n\nimport { and, ilike, isNotNull, isNull, ne, notInArray, or, sql } from 'drizzle-orm'\nimport { QueryError } from 'payload/errors'\nimport { validOperators } from 'payload/types'\n\nimport type { GenericColumn, PostgresAdapter } from '../types'\nimport type { BuildQueryJoinAliases, BuildQueryJoins } from './buildQuery'\n\nimport { buildAndOrConditions } from './buildAndOrConditions'\nimport { createJSONQuery } from './createJSONQuery'\nimport { convertPathToJSONTraversal } from './createJSONQuery/convertPathToJSONTraversal'\nimport { getTableColumnFromPath } from './getTableColumnFromPath'\nimport { operatorMap } from './operatorMap'\nimport { sanitizeQueryValue } from './sanitizeQueryValue'\n\ntype Args = {\n  adapter: PostgresAdapter\n  fields: Field[]\n  joinAliases: BuildQueryJoinAliases\n  joins: BuildQueryJoins\n  locale: string\n  selectFields: Record<string, GenericColumn>\n  tableName: string\n  where: Where\n}\n\nexport async function parseParams({\n  adapter,\n  fields,\n  joinAliases,\n  joins,\n  locale,\n  selectFields,\n  tableName,\n  where,\n}: Args): Promise<SQL> {\n  let result: SQL\n  const constraints: SQL[] = []\n\n  if (typeof where === 'object' && Object.keys(where).length > 0) {\n    // We need to determine if the whereKey is an AND, OR, or a schema path\n    for (const relationOrPath of Object.keys(where)) {\n      if (relationOrPath) {\n        const condition = where[relationOrPath]\n        let conditionOperator: 'and' | 'or'\n        if (relationOrPath.toLowerCase() === 'and') {\n          conditionOperator = 'and'\n        } else if (relationOrPath.toLowerCase() === 'or') {\n          conditionOperator = 'or'\n        }\n        if (Array.isArray(condition)) {\n          const builtConditions = await buildAndOrConditions({\n            adapter,\n            fields,\n            joinAliases,\n            joins,\n            locale,\n            selectFields,\n            tableName,\n            where: condition,\n          })\n          if (builtConditions.length > 0) {\n            if (result) {\n              result = operatorMap[conditionOperator](result, ...builtConditions)\n            } else {\n              result = operatorMap[conditionOperator](...builtConditions)\n            }\n          }\n        } else {\n          // It's a path - and there can be multiple comparisons on a single path.\n          // For example - title like 'test' and title not equal to 'tester'\n          // So we need to loop on keys again here to handle each operator independently\n          const pathOperators = where[relationOrPath]\n          if (typeof pathOperators === 'object') {\n            for (const operator of Object.keys(pathOperators)) {\n              if (validOperators.includes(operator as Operator)) {\n                const {\n                  columnName,\n                  constraints: queryConstraints,\n                  field,\n                  getNotNullColumnByValue,\n                  pathSegments,\n                  rawColumn,\n                  table,\n                } = getTableColumnFromPath({\n                  adapter,\n                  collectionPath: relationOrPath,\n                  fields,\n                  joinAliases,\n                  joins,\n                  locale,\n                  pathSegments: relationOrPath.replace(/__/g, '.').split('.'),\n                  selectFields,\n                  tableName,\n                })\n\n                const val = where[relationOrPath][operator]\n\n                queryConstraints.forEach(({ columnName: col, table: constraintTable, value }) => {\n                  if (typeof value === 'string' && value.indexOf('%') > -1) {\n                    constraints.push(operatorMap.like(constraintTable[col], value))\n                  } else {\n                    constraints.push(operatorMap.equals(constraintTable[col], value))\n                  }\n                })\n\n                if (['json', 'richText'].includes(field.type) && Array.isArray(pathSegments)) {\n                  const segments = pathSegments.slice(1)\n                  segments.unshift(table[columnName].name)\n\n                  if (field.type === 'richText') {\n                    const jsonQuery = createJSONQuery({\n                      operator,\n                      pathSegments: segments,\n                      treatAsArray: ['children'],\n                      treatRootAsArray: true,\n                      value: val,\n                    })\n\n                    constraints.push(sql.raw(jsonQuery))\n                  }\n\n                  if (field.type === 'json') {\n                    const jsonQuery = convertPathToJSONTraversal(pathSegments)\n                    constraints.push(sql.raw(`${table[columnName].name}${jsonQuery} = '%${val}%'`))\n                  }\n\n                  break\n                }\n\n                if (getNotNullColumnByValue) {\n                  const columnName = getNotNullColumnByValue(val)\n                  if (columnName) {\n                    constraints.push(isNotNull(table[columnName]))\n                  } else {\n                    throw new QueryError([{ path: relationOrPath }])\n                  }\n                  break\n                }\n\n                if (operator === 'like') {\n                  constraints.push(\n                    and(...val.split(' ').map((word) => ilike(table[columnName], `%${word}%`))),\n                  )\n                  break\n                }\n\n                const { operator: queryOperator, value: queryValue } = sanitizeQueryValue({\n                  field,\n                  operator,\n                  relationOrPath,\n                  val,\n                })\n\n                if (queryOperator === 'not_equals' && queryValue !== null) {\n                  constraints.push(\n                    or(\n                      isNull(rawColumn || table[columnName]),\n                      /* eslint-disable @typescript-eslint/no-explicit-any */\n                      ne<any>(rawColumn || table[columnName], queryValue),\n                    ),\n                  )\n                } else if (\n                  (field.type === 'relationship' || field.type === 'upload') &&\n                  Array.isArray(queryValue) &&\n                  operator === 'not_in'\n                ) {\n                  constraints.push(\n                    sql`${notInArray(table[columnName], queryValue)} OR\n                    ${table[columnName]}\n                    IS\n                    NULL`,\n                  )\n                } else {\n                  constraints.push(\n                    operatorMap[queryOperator](rawColumn || table[columnName], queryValue),\n                  )\n                }\n              }\n            }\n          }\n        }\n      }\n    }\n  }\n  if (constraints.length > 0) {\n    if (result) {\n      result = and(result, ...constraints)\n    } else {\n      result = and(...constraints)\n    }\n  }\n  if (constraints.length === 1 && !result) {\n    ;[result] = constraints\n  }\n\n  return result\n}\n"],"names":["parseParams","adapter","fields","joinAliases","joins","locale","selectFields","tableName","where","result","constraints","Object","keys","length","relationOrPath","condition","conditionOperator","toLowerCase","Array","isArray","builtConditions","buildAndOrConditions","operatorMap","pathOperators","operator","validOperators","includes","columnName","queryConstraints","field","getNotNullColumnByValue","pathSegments","rawColumn","table","getTableColumnFromPath","collectionPath","replace","split","val","forEach","col","constraintTable","value","indexOf","push","like","equals","type","segments","slice","unshift","name","jsonQuery","createJSONQuery","treatAsArray","treatRootAsArray","sql","raw","convertPathToJSONTraversal","isNotNull","QueryError","path","and","map","word","ilike","queryOperator","queryValue","sanitizeQueryValue","or","isNull","ne","notInArray"],"mappings":"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"}
162
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../src/queries/parseParams.ts"],"sourcesContent":["/* eslint-disable no-await-in-loop */\nimport type { SQL } from 'drizzle-orm'\nimport type { Field, Operator, Where } from 'payload/types'\n\nimport { and, ilike, isNotNull, isNull, ne, notInArray, or, sql } from 'drizzle-orm'\nimport { QueryError } from 'payload/errors'\nimport { validOperators } from 'payload/types'\n\nimport type { GenericColumn, PostgresAdapter } from '../types'\nimport type { BuildQueryJoinAliases, BuildQueryJoins } from './buildQuery'\n\nimport { buildAndOrConditions } from './buildAndOrConditions'\nimport { createJSONQuery } from './createJSONQuery'\nimport { convertPathToJSONTraversal } from './createJSONQuery/convertPathToJSONTraversal'\nimport { getTableColumnFromPath } from './getTableColumnFromPath'\nimport { operatorMap } from './operatorMap'\nimport { sanitizeQueryValue } from './sanitizeQueryValue'\n\ntype Args = {\n  adapter: PostgresAdapter\n  fields: Field[]\n  joinAliases: BuildQueryJoinAliases\n  joins: BuildQueryJoins\n  locale: string\n  selectFields: Record<string, GenericColumn>\n  tableName: string\n  where: Where\n}\n\nexport async function parseParams({\n  adapter,\n  fields,\n  joinAliases,\n  joins,\n  locale,\n  selectFields,\n  tableName,\n  where,\n}: Args): Promise<SQL> {\n  let result: SQL\n  const constraints: SQL[] = []\n\n  if (typeof where === 'object' && Object.keys(where).length > 0) {\n    // We need to determine if the whereKey is an AND, OR, or a schema path\n    for (const relationOrPath of Object.keys(where)) {\n      if (relationOrPath) {\n        const condition = where[relationOrPath]\n        let conditionOperator: 'and' | 'or'\n        if (relationOrPath.toLowerCase() === 'and') {\n          conditionOperator = 'and'\n        } else if (relationOrPath.toLowerCase() === 'or') {\n          conditionOperator = 'or'\n        }\n        if (Array.isArray(condition)) {\n          const builtConditions = await buildAndOrConditions({\n            adapter,\n            fields,\n            joinAliases,\n            joins,\n            locale,\n            selectFields,\n            tableName,\n            where: condition,\n          })\n          if (builtConditions.length > 0) {\n            if (result) {\n              result = operatorMap[conditionOperator](result, ...builtConditions)\n            } else {\n              result = operatorMap[conditionOperator](...builtConditions)\n            }\n          }\n        } else {\n          // It's a path - and there can be multiple comparisons on a single path.\n          // For example - title like 'test' and title not equal to 'tester'\n          // So we need to loop on keys again here to handle each operator independently\n          const pathOperators = where[relationOrPath]\n          if (typeof pathOperators === 'object') {\n            for (const operator of Object.keys(pathOperators)) {\n              if (validOperators.includes(operator as Operator)) {\n                const {\n                  columnName,\n                  constraints: queryConstraints,\n                  field,\n                  getNotNullColumnByValue,\n                  pathSegments,\n                  rawColumn,\n                  table,\n                } = getTableColumnFromPath({\n                  adapter,\n                  collectionPath: relationOrPath,\n                  fields,\n                  joinAliases,\n                  joins,\n                  locale,\n                  pathSegments: relationOrPath.replace(/__/g, '.').split('.'),\n                  selectFields,\n                  tableName,\n                })\n\n                const val = where[relationOrPath][operator]\n\n                queryConstraints.forEach(({ columnName: col, table: constraintTable, value }) => {\n                  if (typeof value === 'string' && value.indexOf('%') > -1) {\n                    constraints.push(operatorMap.like(constraintTable[col], value))\n                  } else {\n                    constraints.push(operatorMap.equals(constraintTable[col], value))\n                  }\n                })\n\n                if (['json', 'richText'].includes(field.type) && Array.isArray(pathSegments)) {\n                  const segments = pathSegments.slice(1)\n                  segments.unshift(table[columnName].name)\n\n                  if (field.type === 'richText') {\n                    const jsonQuery = createJSONQuery({\n                      operator,\n                      pathSegments: segments,\n                      treatAsArray: ['children'],\n                      treatRootAsArray: true,\n                      value: val,\n                    })\n\n                    constraints.push(sql.raw(jsonQuery))\n                  }\n\n                  if (field.type === 'json') {\n                    const jsonQuery = convertPathToJSONTraversal(pathSegments)\n                    constraints.push(sql.raw(`${table[columnName].name}${jsonQuery} = '%${val}%'`))\n                  }\n\n                  break\n                }\n\n                if (getNotNullColumnByValue) {\n                  const columnName = getNotNullColumnByValue(val)\n                  if (columnName) {\n                    constraints.push(isNotNull(table[columnName]))\n                  } else {\n                    throw new QueryError([{ path: relationOrPath }])\n                  }\n                  break\n                }\n\n                if (operator === 'like') {\n                  constraints.push(\n                    and(...val.split(' ').map((word) => ilike(table[columnName], `%${word}%`))),\n                  )\n                  break\n                }\n\n                const sanitizedQueryValue = sanitizeQueryValue({\n                  field,\n                  operator,\n                  relationOrPath,\n                  val,\n                })\n\n                if (sanitizedQueryValue === null) {\n                  break\n                }\n\n                const { operator: queryOperator, value: queryValue } = sanitizedQueryValue\n\n                if (queryOperator === 'not_equals' && queryValue !== null) {\n                  constraints.push(\n                    or(\n                      isNull(rawColumn || table[columnName]),\n                      /* eslint-disable @typescript-eslint/no-explicit-any */\n                      ne<any>(rawColumn || table[columnName], queryValue),\n                    ),\n                  )\n                  break\n                }\n\n                if (\n                  (field.type === 'relationship' || field.type === 'upload') &&\n                  Array.isArray(queryValue) &&\n                  operator === 'not_in'\n                ) {\n                  constraints.push(\n                    sql`${notInArray(table[columnName], queryValue)} OR\n                    ${table[columnName]}\n                    IS\n                    NULL`,\n                  )\n\n                  break\n                }\n\n                constraints.push(\n                  operatorMap[queryOperator](rawColumn || table[columnName], queryValue),\n                )\n              }\n            }\n          }\n        }\n      }\n    }\n  }\n  if (constraints.length > 0) {\n    if (result) {\n      result = and(result, ...constraints)\n    } else {\n      result = and(...constraints)\n    }\n  }\n  if (constraints.length === 1 && !result) {\n    ;[result] = constraints\n  }\n\n  return result\n}\n"],"names":["parseParams","adapter","fields","joinAliases","joins","locale","selectFields","tableName","where","result","constraints","Object","keys","length","relationOrPath","condition","conditionOperator","toLowerCase","Array","isArray","builtConditions","buildAndOrConditions","operatorMap","pathOperators","operator","validOperators","includes","columnName","queryConstraints","field","getNotNullColumnByValue","pathSegments","rawColumn","table","getTableColumnFromPath","collectionPath","replace","split","val","forEach","col","constraintTable","value","indexOf","push","like","equals","type","segments","slice","unshift","name","jsonQuery","createJSONQuery","treatAsArray","treatRootAsArray","sql","raw","convertPathToJSONTraversal","isNotNull","QueryError","path","and","map","word","ilike","sanitizedQueryValue","sanitizeQueryValue","queryOperator","queryValue","or","isNull","ne","notInArray"],"mappings":"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"}
@@ -1 +1 @@
1
- {"version":3,"file":"sanitizeQueryValue.d.ts","sourceRoot":"","sources":["../../src/queries/sanitizeQueryValue.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,KAAK,KAAK,EAAE,KAAK,UAAU,EAAoB,MAAM,eAAe,CAAA;AAG7E,KAAK,sBAAsB,GAAG;IAC5B,KAAK,EAAE,KAAK,GAAG,UAAU,CAAA;IACzB,QAAQ,EAAE,MAAM,CAAA;IAChB,cAAc,EAAE,MAAM,CAAA;IACtB,GAAG,EAAE,GAAG,CAAA;CACT,CAAA;AAED,eAAO,MAAM,kBAAkB,2DAK5B,sBAAsB;cAAe,MAAM;WAAS,OAAO;CA6E7D,CAAA"}
1
+ {"version":3,"file":"sanitizeQueryValue.d.ts","sourceRoot":"","sources":["../../src/queries/sanitizeQueryValue.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,KAAK,KAAK,EAAE,KAAK,UAAU,EAAoB,MAAM,eAAe,CAAA;AAG7E,KAAK,sBAAsB,GAAG;IAC5B,KAAK,EAAE,KAAK,GAAG,UAAU,CAAA;IACzB,QAAQ,EAAE,MAAM,CAAA;IAChB,cAAc,EAAE,MAAM,CAAA;IACtB,GAAG,EAAE,GAAG,CAAA;CACT,CAAA;AAED,eAAO,MAAM,kBAAkB,2DAK5B,sBAAsB;cAAe,MAAM;WAAS,OAAO;CAmF7D,CAAA"}
@@ -38,10 +38,15 @@ const sanitizeQueryValue = ({ field, operator: operatorArg, relationOrPath, val
38
38
  'all',
39
39
  'in',
40
40
  'not_in'
41
- ].includes(operator) && typeof formattedValue === 'string') {
42
- formattedValue = (0, _utilities.createArrayFromCommaDelineated)(formattedValue);
43
- if (field.type === 'number') {
44
- formattedValue = formattedValue.map((arrayVal)=>parseFloat(arrayVal));
41
+ ].includes(operator)) {
42
+ if (typeof formattedValue === 'string') {
43
+ formattedValue = (0, _utilities.createArrayFromCommaDelineated)(formattedValue);
44
+ if (field.type === 'number') {
45
+ formattedValue = formattedValue.map((arrayVal)=>parseFloat(arrayVal));
46
+ }
47
+ }
48
+ if (!Array.isArray(formattedValue) || formattedValue.length === 0) {
49
+ return null;
45
50
  }
46
51
  }
47
52
  if (field.type === 'number' && typeof formattedValue === 'string') {
@@ -87,4 +92,4 @@ const sanitizeQueryValue = ({ field, operator: operatorArg, relationOrPath, val
87
92
  };
88
93
  };
89
94
 
90
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9xdWVyaWVzL3Nhbml0aXplUXVlcnlWYWx1ZS50cyJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBBUElFcnJvciB9IGZyb20gJ3BheWxvYWQvZXJyb3JzJ1xuaW1wb3J0IHsgdHlwZSBGaWVsZCwgdHlwZSBUYWJBc0ZpZWxkLCBmaWVsZEFmZmVjdHNEYXRhIH0gZnJvbSAncGF5bG9hZC90eXBlcydcbmltcG9ydCB7IGNyZWF0ZUFycmF5RnJvbUNvbW1hRGVsaW5lYXRlZCB9IGZyb20gJ3BheWxvYWQvdXRpbGl0aWVzJ1xuXG50eXBlIFNhbml0aXplUXVlcnlWYWx1ZUFyZ3MgPSB7XG4gIGZpZWxkOiBGaWVsZCB8IFRhYkFzRmllbGRcbiAgb3BlcmF0b3I6IHN0cmluZ1xuICByZWxhdGlvbk9yUGF0aDogc3RyaW5nXG4gIHZhbDogYW55XG59XG5cbmV4cG9ydCBjb25zdCBzYW5pdGl6ZVF1ZXJ5VmFsdWUgPSAoe1xuICBmaWVsZCxcbiAgb3BlcmF0b3I6IG9wZXJhdG9yQXJnLFxuICByZWxhdGlvbk9yUGF0aCxcbiAgdmFsLFxufTogU2FuaXRpemVRdWVyeVZhbHVlQXJncyk6IHsgb3BlcmF0b3I6IHN0cmluZzsgdmFsdWU6IHVua25vd24gfSA9PiB7XG4gIGxldCBvcGVyYXRvciA9IG9wZXJhdG9yQXJnXG4gIGxldCBmb3JtYXR0ZWRWYWx1ZSA9IHZhbFxuXG4gIGlmICghZmllbGRBZmZlY3RzRGF0YShmaWVsZCkpIHJldHVybiB7IG9wZXJhdG9yLCB2YWx1ZTogZm9ybWF0dGVkVmFsdWUgfVxuXG4gIGlmIChcbiAgICAoZmllbGQudHlwZSA9PT0gJ3JlbGF0aW9uc2hpcCcgfHwgZmllbGQudHlwZSA9PT0gJ3VwbG9hZCcpICYmXG4gICAgIXJlbGF0aW9uT3JQYXRoLmVuZHNXaXRoKCdyZWxhdGlvblRvJykgJiZcbiAgICBBcnJheS5pc0FycmF5KGZvcm1hdHRlZFZhbHVlKVxuICApIHtcbiAgICBjb25zdCBhbGxQb3NzaWJsZUlEVHlwZXM6IChudW1iZXIgfCBzdHJpbmcpW10gPSBbXVxuICAgIGZvcm1hdHRlZFZhbHVlLmZvckVhY2goKHZhbCkgPT4ge1xuICAgICAgaWYgKHR5cGVvZiB2YWwgPT09ICdzdHJpbmcnKSB7XG4gICAgICAgIGFsbFBvc3NpYmxlSURUeXBlcy5wdXNoKHZhbCwgcGFyc2VJbnQodmFsKSlcbiAgICAgIH0gZWxzZSB7XG4gICAgICAgIGFsbFBvc3NpYmxlSURUeXBlcy5wdXNoKHZhbCwgU3RyaW5nKHZhbCkpXG4gICAgICB9XG4gICAgfSlcbiAgICBmb3JtYXR0ZWRWYWx1ZSA9IGFsbFBvc3NpYmxlSURUeXBlc1xuICB9XG5cbiAgLy8gQ2FzdCBpbmNvbWluZyB2YWx1ZXMgYXMgcHJvcGVyIHNlYXJjaGFibGUgdHlwZXNcbiAgaWYgKGZpZWxkLnR5cGUgPT09ICdjaGVja2JveCcgJiYgdHlwZW9mIHZhbCA9PT0gJ3N0cmluZycpIHtcbiAgICBpZiAodmFsLnRvTG93ZXJDYXNlKCkgPT09ICd0cnVlJykgZm9ybWF0dGVkVmFsdWUgPSB0cnVlXG4gICAgaWYgKHZhbC50b0xvd2VyQ2FzZSgpID09PSAnZmFsc2UnKSBmb3JtYXR0ZWRWYWx1ZSA9IGZhbHNlXG4gIH1cblxuICBpZiAoWydhbGwnLCAnaW4nLCAnbm90X2luJ10uaW5jbHVkZXMob3BlcmF0b3IpICYmIHR5cGVvZiBmb3JtYXR0ZWRWYWx1ZSA9PT0gJ3N0cmluZycpIHtcbiAgICBmb3JtYXR0ZWRWYWx1ZSA9IGNyZWF0ZUFycmF5RnJvbUNvbW1hRGVsaW5lYXRlZChmb3JtYXR0ZWRWYWx1ZSlcblxuICAgIGlmIChmaWVsZC50eXBlID09PSAnbnVtYmVyJykge1xuICAgICAgZm9ybWF0dGVkVmFsdWUgPSBmb3JtYXR0ZWRWYWx1ZS5tYXAoKGFycmF5VmFsKSA9PiBwYXJzZUZsb2F0KGFycmF5VmFsKSlcbiAgICB9XG4gIH1cblxuICBpZiAoZmllbGQudHlwZSA9PT0gJ251bWJlcicgJiYgdHlwZW9mIGZvcm1hdHRlZFZhbHVlID09PSAnc3RyaW5nJykge1xuICAgIGZvcm1hdHRlZFZhbHVlID0gTnVtYmVyKHZhbClcbiAgfVxuXG4gIGlmIChmaWVsZC50eXBlID09PSAnZGF0ZScpIHtcbiAgICBpZiAodHlwZW9mIHZhbCA9PT0gJ3N0cmluZycpIHtcbiAgICAgIGZvcm1hdHRlZFZhbHVlID0gbmV3IERhdGUodmFsKVxuICAgICAgaWYgKE51bWJlci5pc05hTihEYXRlLnBhcnNlKGZvcm1hdHRlZFZhbHVlKSkpIHtcbiAgICAgICAgcmV0dXJuIHsgb3BlcmF0b3IsIHZhbHVlOiB1bmRlZmluZWQgfVxuICAgICAgfVxuICAgIH1cblxuICAgIGlmICh0eXBlb2YgdmFsID09PSAnbnVtYmVyJykge1xuICAgICAgZm9ybWF0dGVkVmFsdWUgPSBuZXcgRGF0ZSh2YWwpXG4gICAgfVxuICB9XG5cbiAgaWYgKFsncmVsYXRpb25zaGlwJywgJ3VwbG9hZCddLmluY2x1ZGVzKGZpZWxkLnR5cGUpKSB7XG4gICAgaWYgKHZhbCA9PT0gJ251bGwnKSB7XG4gICAgICBmb3JtYXR0ZWRWYWx1ZSA9IG51bGxcbiAgICB9XG4gIH1cblxuICBpZiAob3BlcmF0b3IgPT09ICduZWFyJyB8fCBvcGVyYXRvciA9PT0gJ3dpdGhpbicgfHwgb3BlcmF0b3IgPT09ICdpbnRlcnNlY3RzJykge1xuICAgIHRocm93IG5ldyBBUElFcnJvcihcbiAgICAgIGBRdWVyeWluZyB3aXRoICcke29wZXJhdG9yfScgaXMgbm90IHN1cHBvcnRlZCB3aXRoIHRoZSBwb3N0Z3JlcyBkYXRhYmFzZSBhZGFwdGVyLmAsXG4gICAgKVxuICB9XG5cbiAgaWYgKG9wZXJhdG9yID09PSAnY29udGFpbnMnKSB7XG4gICAgZm9ybWF0dGVkVmFsdWUgPSBgJSR7Zm9ybWF0dGVkVmFsdWV9JWBcbiAgfVxuXG4gIGlmIChvcGVyYXRvciA9PT0gJ2V4aXN0cycpIHtcbiAgICBmb3JtYXR0ZWRWYWx1ZSA9IGZvcm1hdHRlZFZhbHVlID09PSAndHJ1ZScgfHwgZm9ybWF0dGVkVmFsdWUgPT09IHRydWVcbiAgICBpZiAoZm9ybWF0dGVkVmFsdWUgPT09IGZhbHNlKSB7XG4gICAgICBvcGVyYXRvciA9ICdpc051bGwnXG4gICAgfVxuICB9XG5cbiAgcmV0dXJuIHsgb3BlcmF0b3IsIHZhbHVlOiBmb3JtYXR0ZWRWYWx1ZSB9XG59XG4iXSwibmFtZXMiOlsic2FuaXRpemVRdWVyeVZhbHVlIiwiZmllbGQiLCJvcGVyYXRvciIsIm9wZXJhdG9yQXJnIiwicmVsYXRpb25PclBhdGgiLCJ2YWwiLCJmb3JtYXR0ZWRWYWx1ZSIsImZpZWxkQWZmZWN0c0RhdGEiLCJ2YWx1ZSIsInR5cGUiLCJlbmRzV2l0aCIsIkFycmF5IiwiaXNBcnJheSIsImFsbFBvc3NpYmxlSURUeXBlcyIsImZvckVhY2giLCJwdXNoIiwicGFyc2VJbnQiLCJTdHJpbmciLCJ0b0xvd2VyQ2FzZSIsImluY2x1ZGVzIiwiY3JlYXRlQXJyYXlGcm9tQ29tbWFEZWxpbmVhdGVkIiwibWFwIiwiYXJyYXlWYWwiLCJwYXJzZUZsb2F0IiwiTnVtYmVyIiwiRGF0ZSIsImlzTmFOIiwicGFyc2UiLCJ1bmRlZmluZWQiLCJBUElFcnJvciJdLCJtYXBwaW5ncyI6Ijs7OzsrQkFXYUE7OztlQUFBQTs7O3dCQVhZO3VCQUNxQzsyQkFDZjtBQVN4QyxNQUFNQSxxQkFBcUIsQ0FBQyxFQUNqQ0MsS0FBSyxFQUNMQyxVQUFVQyxXQUFXLEVBQ3JCQyxjQUFjLEVBQ2RDLEdBQUcsRUFDb0I7SUFDdkIsSUFBSUgsV0FBV0M7SUFDZixJQUFJRyxpQkFBaUJEO0lBRXJCLElBQUksQ0FBQ0UsSUFBQUEsdUJBQWdCLEVBQUNOLFFBQVEsT0FBTztRQUFFQztRQUFVTSxPQUFPRjtJQUFlO0lBRXZFLElBQ0UsQUFBQ0wsQ0FBQUEsTUFBTVEsSUFBSSxLQUFLLGtCQUFrQlIsTUFBTVEsSUFBSSxLQUFLLFFBQU8sS0FDeEQsQ0FBQ0wsZUFBZU0sUUFBUSxDQUFDLGlCQUN6QkMsTUFBTUMsT0FBTyxDQUFDTixpQkFDZDtRQUNBLE1BQU1PLHFCQUEwQyxFQUFFO1FBQ2xEUCxlQUFlUSxPQUFPLENBQUMsQ0FBQ1Q7WUFDdEIsSUFBSSxPQUFPQSxRQUFRLFVBQVU7Z0JBQzNCUSxtQkFBbUJFLElBQUksQ0FBQ1YsS0FBS1csU0FBU1g7WUFDeEMsT0FBTztnQkFDTFEsbUJBQW1CRSxJQUFJLENBQUNWLEtBQUtZLE9BQU9aO1lBQ3RDO1FBQ0Y7UUFDQUMsaUJBQWlCTztJQUNuQjtJQUVBLGtEQUFrRDtJQUNsRCxJQUFJWixNQUFNUSxJQUFJLEtBQUssY0FBYyxPQUFPSixRQUFRLFVBQVU7UUFDeEQsSUFBSUEsSUFBSWEsV0FBVyxPQUFPLFFBQVFaLGlCQUFpQjtRQUNuRCxJQUFJRCxJQUFJYSxXQUFXLE9BQU8sU0FBU1osaUJBQWlCO0lBQ3REO0lBRUEsSUFBSTtRQUFDO1FBQU87UUFBTTtLQUFTLENBQUNhLFFBQVEsQ0FBQ2pCLGFBQWEsT0FBT0ksbUJBQW1CLFVBQVU7UUFDcEZBLGlCQUFpQmMsSUFBQUEseUNBQThCLEVBQUNkO1FBRWhELElBQUlMLE1BQU1RLElBQUksS0FBSyxVQUFVO1lBQzNCSCxpQkFBaUJBLGVBQWVlLEdBQUcsQ0FBQyxDQUFDQyxXQUFhQyxXQUFXRDtRQUMvRDtJQUNGO0lBRUEsSUFBSXJCLE1BQU1RLElBQUksS0FBSyxZQUFZLE9BQU9ILG1CQUFtQixVQUFVO1FBQ2pFQSxpQkFBaUJrQixPQUFPbkI7SUFDMUI7SUFFQSxJQUFJSixNQUFNUSxJQUFJLEtBQUssUUFBUTtRQUN6QixJQUFJLE9BQU9KLFFBQVEsVUFBVTtZQUMzQkMsaUJBQWlCLElBQUltQixLQUFLcEI7WUFDMUIsSUFBSW1CLE9BQU9FLEtBQUssQ0FBQ0QsS0FBS0UsS0FBSyxDQUFDckIsa0JBQWtCO2dCQUM1QyxPQUFPO29CQUFFSjtvQkFBVU0sT0FBT29CO2dCQUFVO1lBQ3RDO1FBQ0Y7UUFFQSxJQUFJLE9BQU92QixRQUFRLFVBQVU7WUFDM0JDLGlCQUFpQixJQUFJbUIsS0FBS3BCO1FBQzVCO0lBQ0Y7SUFFQSxJQUFJO1FBQUM7UUFBZ0I7S0FBUyxDQUFDYyxRQUFRLENBQUNsQixNQUFNUSxJQUFJLEdBQUc7UUFDbkQsSUFBSUosUUFBUSxRQUFRO1lBQ2xCQyxpQkFBaUI7UUFDbkI7SUFDRjtJQUVBLElBQUlKLGFBQWEsVUFBVUEsYUFBYSxZQUFZQSxhQUFhLGNBQWM7UUFDN0UsTUFBTSxJQUFJMkIsZ0JBQVEsQ0FDaEIsQ0FBQyxlQUFlLEVBQUUzQixTQUFTLHNEQUFzRCxDQUFDO0lBRXRGO0lBRUEsSUFBSUEsYUFBYSxZQUFZO1FBQzNCSSxpQkFBaUIsQ0FBQyxDQUFDLEVBQUVBLGVBQWUsQ0FBQyxDQUFDO0lBQ3hDO0lBRUEsSUFBSUosYUFBYSxVQUFVO1FBQ3pCSSxpQkFBaUJBLG1CQUFtQixVQUFVQSxtQkFBbUI7UUFDakUsSUFBSUEsbUJBQW1CLE9BQU87WUFDNUJKLFdBQVc7UUFDYjtJQUNGO0lBRUEsT0FBTztRQUFFQTtRQUFVTSxPQUFPRjtJQUFlO0FBQzNDIn0=
95
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9xdWVyaWVzL3Nhbml0aXplUXVlcnlWYWx1ZS50cyJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBBUElFcnJvciB9IGZyb20gJ3BheWxvYWQvZXJyb3JzJ1xuaW1wb3J0IHsgdHlwZSBGaWVsZCwgdHlwZSBUYWJBc0ZpZWxkLCBmaWVsZEFmZmVjdHNEYXRhIH0gZnJvbSAncGF5bG9hZC90eXBlcydcbmltcG9ydCB7IGNyZWF0ZUFycmF5RnJvbUNvbW1hRGVsaW5lYXRlZCB9IGZyb20gJ3BheWxvYWQvdXRpbGl0aWVzJ1xuXG50eXBlIFNhbml0aXplUXVlcnlWYWx1ZUFyZ3MgPSB7XG4gIGZpZWxkOiBGaWVsZCB8IFRhYkFzRmllbGRcbiAgb3BlcmF0b3I6IHN0cmluZ1xuICByZWxhdGlvbk9yUGF0aDogc3RyaW5nXG4gIHZhbDogYW55XG59XG5cbmV4cG9ydCBjb25zdCBzYW5pdGl6ZVF1ZXJ5VmFsdWUgPSAoe1xuICBmaWVsZCxcbiAgb3BlcmF0b3I6IG9wZXJhdG9yQXJnLFxuICByZWxhdGlvbk9yUGF0aCxcbiAgdmFsLFxufTogU2FuaXRpemVRdWVyeVZhbHVlQXJncyk6IHsgb3BlcmF0b3I6IHN0cmluZzsgdmFsdWU6IHVua25vd24gfSA9PiB7XG4gIGxldCBvcGVyYXRvciA9IG9wZXJhdG9yQXJnXG4gIGxldCBmb3JtYXR0ZWRWYWx1ZSA9IHZhbFxuXG4gIGlmICghZmllbGRBZmZlY3RzRGF0YShmaWVsZCkpIHJldHVybiB7IG9wZXJhdG9yLCB2YWx1ZTogZm9ybWF0dGVkVmFsdWUgfVxuXG4gIGlmIChcbiAgICAoZmllbGQudHlwZSA9PT0gJ3JlbGF0aW9uc2hpcCcgfHwgZmllbGQudHlwZSA9PT0gJ3VwbG9hZCcpICYmXG4gICAgIXJlbGF0aW9uT3JQYXRoLmVuZHNXaXRoKCdyZWxhdGlvblRvJykgJiZcbiAgICBBcnJheS5pc0FycmF5KGZvcm1hdHRlZFZhbHVlKVxuICApIHtcbiAgICBjb25zdCBhbGxQb3NzaWJsZUlEVHlwZXM6IChudW1iZXIgfCBzdHJpbmcpW10gPSBbXVxuICAgIGZvcm1hdHRlZFZhbHVlLmZvckVhY2goKHZhbCkgPT4ge1xuICAgICAgaWYgKHR5cGVvZiB2YWwgPT09ICdzdHJpbmcnKSB7XG4gICAgICAgIGFsbFBvc3NpYmxlSURUeXBlcy5wdXNoKHZhbCwgcGFyc2VJbnQodmFsKSlcbiAgICAgIH0gZWxzZSB7XG4gICAgICAgIGFsbFBvc3NpYmxlSURUeXBlcy5wdXNoKHZhbCwgU3RyaW5nKHZhbCkpXG4gICAgICB9XG4gICAgfSlcbiAgICBmb3JtYXR0ZWRWYWx1ZSA9IGFsbFBvc3NpYmxlSURUeXBlc1xuICB9XG5cbiAgLy8gQ2FzdCBpbmNvbWluZyB2YWx1ZXMgYXMgcHJvcGVyIHNlYXJjaGFibGUgdHlwZXNcbiAgaWYgKGZpZWxkLnR5cGUgPT09ICdjaGVja2JveCcgJiYgdHlwZW9mIHZhbCA9PT0gJ3N0cmluZycpIHtcbiAgICBpZiAodmFsLnRvTG93ZXJDYXNlKCkgPT09ICd0cnVlJykgZm9ybWF0dGVkVmFsdWUgPSB0cnVlXG4gICAgaWYgKHZhbC50b0xvd2VyQ2FzZSgpID09PSAnZmFsc2UnKSBmb3JtYXR0ZWRWYWx1ZSA9IGZhbHNlXG4gIH1cblxuICBpZiAoWydhbGwnLCAnaW4nLCAnbm90X2luJ10uaW5jbHVkZXMob3BlcmF0b3IpKSB7XG4gICAgaWYgKHR5cGVvZiBmb3JtYXR0ZWRWYWx1ZSA9PT0gJ3N0cmluZycpIHtcbiAgICAgIGZvcm1hdHRlZFZhbHVlID0gY3JlYXRlQXJyYXlGcm9tQ29tbWFEZWxpbmVhdGVkKGZvcm1hdHRlZFZhbHVlKVxuXG4gICAgICBpZiAoZmllbGQudHlwZSA9PT0gJ251bWJlcicpIHtcbiAgICAgICAgZm9ybWF0dGVkVmFsdWUgPSBmb3JtYXR0ZWRWYWx1ZS5tYXAoKGFycmF5VmFsKSA9PiBwYXJzZUZsb2F0KGFycmF5VmFsKSlcbiAgICAgIH1cbiAgICB9XG5cbiAgICBpZiAoIUFycmF5LmlzQXJyYXkoZm9ybWF0dGVkVmFsdWUpIHx8IGZvcm1hdHRlZFZhbHVlLmxlbmd0aCA9PT0gMCkge1xuICAgICAgcmV0dXJuIG51bGxcbiAgICB9XG4gIH1cblxuICBpZiAoZmllbGQudHlwZSA9PT0gJ251bWJlcicgJiYgdHlwZW9mIGZvcm1hdHRlZFZhbHVlID09PSAnc3RyaW5nJykge1xuICAgIGZvcm1hdHRlZFZhbHVlID0gTnVtYmVyKHZhbClcbiAgfVxuXG4gIGlmIChmaWVsZC50eXBlID09PSAnZGF0ZScpIHtcbiAgICBpZiAodHlwZW9mIHZhbCA9PT0gJ3N0cmluZycpIHtcbiAgICAgIGZvcm1hdHRlZFZhbHVlID0gbmV3IERhdGUodmFsKVxuICAgICAgaWYgKE51bWJlci5pc05hTihEYXRlLnBhcnNlKGZvcm1hdHRlZFZhbHVlKSkpIHtcbiAgICAgICAgcmV0dXJuIHsgb3BlcmF0b3IsIHZhbHVlOiB1bmRlZmluZWQgfVxuICAgICAgfVxuICAgIH1cblxuICAgIGlmICh0eXBlb2YgdmFsID09PSAnbnVtYmVyJykge1xuICAgICAgZm9ybWF0dGVkVmFsdWUgPSBuZXcgRGF0ZSh2YWwpXG4gICAgfVxuICB9XG5cbiAgaWYgKFsncmVsYXRpb25zaGlwJywgJ3VwbG9hZCddLmluY2x1ZGVzKGZpZWxkLnR5cGUpKSB7XG4gICAgaWYgKHZhbCA9PT0gJ251bGwnKSB7XG4gICAgICBmb3JtYXR0ZWRWYWx1ZSA9IG51bGxcbiAgICB9XG4gIH1cblxuICBpZiAob3BlcmF0b3IgPT09ICduZWFyJyB8fCBvcGVyYXRvciA9PT0gJ3dpdGhpbicgfHwgb3BlcmF0b3IgPT09ICdpbnRlcnNlY3RzJykge1xuICAgIHRocm93IG5ldyBBUElFcnJvcihcbiAgICAgIGBRdWVyeWluZyB3aXRoICcke29wZXJhdG9yfScgaXMgbm90IHN1cHBvcnRlZCB3aXRoIHRoZSBwb3N0Z3JlcyBkYXRhYmFzZSBhZGFwdGVyLmAsXG4gICAgKVxuICB9XG5cbiAgaWYgKG9wZXJhdG9yID09PSAnY29udGFpbnMnKSB7XG4gICAgZm9ybWF0dGVkVmFsdWUgPSBgJSR7Zm9ybWF0dGVkVmFsdWV9JWBcbiAgfVxuXG4gIGlmIChvcGVyYXRvciA9PT0gJ2V4aXN0cycpIHtcbiAgICBmb3JtYXR0ZWRWYWx1ZSA9IGZvcm1hdHRlZFZhbHVlID09PSAndHJ1ZScgfHwgZm9ybWF0dGVkVmFsdWUgPT09IHRydWVcbiAgICBpZiAoZm9ybWF0dGVkVmFsdWUgPT09IGZhbHNlKSB7XG4gICAgICBvcGVyYXRvciA9ICdpc051bGwnXG4gICAgfVxuICB9XG5cbiAgcmV0dXJuIHsgb3BlcmF0b3IsIHZhbHVlOiBmb3JtYXR0ZWRWYWx1ZSB9XG59XG4iXSwibmFtZXMiOlsic2FuaXRpemVRdWVyeVZhbHVlIiwiZmllbGQiLCJvcGVyYXRvciIsIm9wZXJhdG9yQXJnIiwicmVsYXRpb25PclBhdGgiLCJ2YWwiLCJmb3JtYXR0ZWRWYWx1ZSIsImZpZWxkQWZmZWN0c0RhdGEiLCJ2YWx1ZSIsInR5cGUiLCJlbmRzV2l0aCIsIkFycmF5IiwiaXNBcnJheSIsImFsbFBvc3NpYmxlSURUeXBlcyIsImZvckVhY2giLCJwdXNoIiwicGFyc2VJbnQiLCJTdHJpbmciLCJ0b0xvd2VyQ2FzZSIsImluY2x1ZGVzIiwiY3JlYXRlQXJyYXlGcm9tQ29tbWFEZWxpbmVhdGVkIiwibWFwIiwiYXJyYXlWYWwiLCJwYXJzZUZsb2F0IiwibGVuZ3RoIiwiTnVtYmVyIiwiRGF0ZSIsImlzTmFOIiwicGFyc2UiLCJ1bmRlZmluZWQiLCJBUElFcnJvciJdLCJtYXBwaW5ncyI6Ijs7OzsrQkFXYUE7OztlQUFBQTs7O3dCQVhZO3VCQUNxQzsyQkFDZjtBQVN4QyxNQUFNQSxxQkFBcUIsQ0FBQyxFQUNqQ0MsS0FBSyxFQUNMQyxVQUFVQyxXQUFXLEVBQ3JCQyxjQUFjLEVBQ2RDLEdBQUcsRUFDb0I7SUFDdkIsSUFBSUgsV0FBV0M7SUFDZixJQUFJRyxpQkFBaUJEO0lBRXJCLElBQUksQ0FBQ0UsSUFBQUEsdUJBQWdCLEVBQUNOLFFBQVEsT0FBTztRQUFFQztRQUFVTSxPQUFPRjtJQUFlO0lBRXZFLElBQ0UsQUFBQ0wsQ0FBQUEsTUFBTVEsSUFB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
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@payloadcms/db-postgres",
3
- "version": "0.1.7",
3
+ "version": "0.1.9",
4
4
  "description": "The officially supported Postgres database adapter for Payload",
5
5
  "repository": "https://github.com/payloadcms/payload",
6
6
  "license": "MIT",
@@ -25,7 +25,7 @@
25
25
  "@types/pg": "8.10.2",
26
26
  "@types/to-snake-case": "1.0.0",
27
27
  "@payloadcms/eslint-config": "0.0.1",
28
- "payload": "2.0.6"
28
+ "payload": "2.0.7"
29
29
  },
30
30
  "publishConfig": {
31
31
  "registry": "https://registry.npmjs.org/"