@payloadcms/db-postgres 0.1.7 → 0.1.8
Sign up to get free protection for your applications and to get access to all the features.
- package/dist/find/findMany.d.ts.map +1 -1
- package/dist/find/findMany.js +4 -3
- package/dist/queries/parseParams.d.ts.map +1 -1
- package/dist/queries/parseParams.js +11 -5
- package/dist/queries/sanitizeQueryValue.d.ts.map +1 -1
- package/dist/queries/sanitizeQueryValue.js +10 -5
- package/package.json +2 -2
@@ -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;;;;;;;;;;;
|
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"}
|
package/dist/find/findMany.js
CHANGED
@@ -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
|
-
|
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":"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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,
|
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
|
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
|
-
|
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
|
-
|
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;
|
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)
|
42
|
-
|
43
|
-
|
44
|
-
|
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,
|
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.
|
3
|
+
"version": "0.1.8",
|
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.
|
28
|
+
"payload": "2.0.7"
|
29
29
|
},
|
30
30
|
"publishConfig": {
|
31
31
|
"registry": "https://registry.npmjs.org/"
|