@payloadcms/db-postgres 0.1.13 → 0.2.0
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 +7 -6
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +36 -3
- package/dist/queries/getTableColumnFromPath.d.ts.map +1 -1
- package/dist/queries/getTableColumnFromPath.js +4 -1
- package/dist/upsertRow/insertArrays.js +2 -2
- package/package.json +4 -3
@@ -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;;;;;;;;;;;EA+KN,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
|
-
|
24
|
+
const limit = limitArg ?? 10;
|
25
25
|
let totalDocs;
|
26
26
|
let totalPages;
|
27
27
|
let hasPrevPage;
|
@@ -37,6 +37,7 @@ const findMany = async function find({ adapter, fields, limit: limitArg, locale,
|
|
37
37
|
where: whereArg
|
38
38
|
});
|
39
39
|
const orderedIDMap = {};
|
40
|
+
let orderedIDs;
|
40
41
|
const selectDistinctMethods = [];
|
41
42
|
if (orderBy?.order && orderBy?.column) {
|
42
43
|
selectDistinctMethods.push({
|
@@ -116,7 +117,8 @@ const findMany = async function find({ adapter, fields, limit: limitArg, locale,
|
|
116
117
|
selectDistinctResult.forEach(({ id }, i)=>{
|
117
118
|
orderedIDMap[id] = i;
|
118
119
|
});
|
119
|
-
|
120
|
+
orderedIDs = Object.keys(orderedIDMap);
|
121
|
+
findManyArgs.where = (0, _drizzleorm.inArray)(adapter.tables[tableName].id, orderedIDs);
|
120
122
|
} else {
|
121
123
|
findManyArgs.limit = limitArg === 0 ? undefined : limitArg;
|
122
124
|
const offset = skip || (page - 1) * limitArg;
|
@@ -127,7 +129,7 @@ const findMany = async function find({ adapter, fields, limit: limitArg, locale,
|
|
127
129
|
findManyArgs.orderBy = orderBy.order(orderBy.column);
|
128
130
|
}
|
129
131
|
const findPromise = db.query[tableName].findMany(findManyArgs);
|
130
|
-
if (pagination !== false
|
132
|
+
if (pagination !== false && (orderedIDs ? orderedIDs?.length >= limit : true)) {
|
131
133
|
const selectCountMethods = [];
|
132
134
|
joinAliases.forEach(({ condition, table })=>{
|
133
135
|
selectCountMethods.push({
|
@@ -167,9 +169,8 @@ const findMany = async function find({ adapter, fields, limit: limitArg, locale,
|
|
167
169
|
if (Object.keys(orderedIDMap).length > 0) {
|
168
170
|
rawDocs.sort((a, b)=>orderedIDMap[a.id] - orderedIDMap[b.id]);
|
169
171
|
}
|
170
|
-
if (pagination === false) {
|
172
|
+
if (pagination === false || !totalDocs) {
|
171
173
|
totalDocs = rawDocs.length;
|
172
|
-
limit = totalDocs;
|
173
174
|
totalPages = 1;
|
174
175
|
pagingCounter = 1;
|
175
176
|
hasPrevPage = false;
|
@@ -196,4 +197,4 @@ const findMany = async function find({ adapter, fields, limit: limitArg, locale,
|
|
196
197
|
};
|
197
198
|
};
|
198
199
|
|
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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"}
|
200
|
+
//# 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  const 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  let orderedIDs: (number | string)[]\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    orderedIDs = Object.keys(orderedIDMap)\n    findManyArgs.where = inArray(adapter.tables[tableName].id, orderedIDs)\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 && (orderedIDs ? orderedIDs?.length >= limit : true)) {\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 || !totalDocs) {\n    totalDocs = rawDocs.length\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","orderedIDs","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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"}
|
package/dist/index.d.ts.map
CHANGED
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAMA,OAAO,KAAK,EAAE,IAAI,EAAmB,qBAAqB,EAAE,MAAM,SAAS,CAAA;AAmC3E,YAAY,EAAE,eAAe,EAAE,aAAa,EAAE,MAAM,SAAS,CAAA;AAE7D,wBAAgB,eAAe,CAAC,IAAI,EAAE,IAAI,GAAG,qBAAqB,CA4DjE"}
|
package/dist/index.js
CHANGED
@@ -8,6 +8,7 @@ Object.defineProperty(exports, "postgresAdapter", {
|
|
8
8
|
return postgresAdapter;
|
9
9
|
}
|
10
10
|
});
|
11
|
+
const _fs = /*#__PURE__*/ _interop_require_default(require("fs"));
|
11
12
|
const _path = /*#__PURE__*/ _interop_require_default(require("path"));
|
12
13
|
const _database = require("payload/database");
|
13
14
|
const _connect = require("./connect");
|
@@ -49,7 +50,7 @@ function _interop_require_default(obj) {
|
|
49
50
|
}
|
50
51
|
function postgresAdapter(args) {
|
51
52
|
function adapter({ payload }) {
|
52
|
-
const migrationDir = args.migrationDir
|
53
|
+
const migrationDir = findMigrationDir(args.migrationDir);
|
53
54
|
(0, _extendWebpackConfig.extendWebpackConfig)(payload.config);
|
54
55
|
(0, _extendViteConfig.extendViteConfig)(payload.config);
|
55
56
|
return (0, _database.createDatabaseAdapter)({
|
@@ -57,6 +58,7 @@ function postgresAdapter(args) {
|
|
57
58
|
// Postgres-specific
|
58
59
|
drizzle: undefined,
|
59
60
|
enums: {},
|
61
|
+
fieldConstraints: {},
|
60
62
|
pool: undefined,
|
61
63
|
poolOptions: args.pool,
|
62
64
|
push: args.push,
|
@@ -64,7 +66,6 @@ function postgresAdapter(args) {
|
|
64
66
|
schema: {},
|
65
67
|
sessions: {},
|
66
68
|
tables: {},
|
67
|
-
fieldConstraints: {},
|
68
69
|
// DatabaseAdapter
|
69
70
|
beginTransaction: _beginTransaction.beginTransaction,
|
70
71
|
commitTransaction: _commitTransaction.commitTransaction,
|
@@ -103,5 +104,37 @@ function postgresAdapter(args) {
|
|
103
104
|
}
|
104
105
|
return adapter;
|
105
106
|
}
|
107
|
+
/**
|
108
|
+
* Attempt to find migrations directory.
|
109
|
+
*
|
110
|
+
* Checks for the following directories in order:
|
111
|
+
* - `migrationDir` argument from Payload config
|
112
|
+
* - `src/migrations`
|
113
|
+
* - `dist/migrations`
|
114
|
+
* - `migrations`
|
115
|
+
*
|
116
|
+
* Defaults to `src/migrations`
|
117
|
+
*
|
118
|
+
* @param migrationDir
|
119
|
+
* @returns
|
120
|
+
*/ function findMigrationDir(migrationDir) {
|
121
|
+
const cwd = process.cwd();
|
122
|
+
const srcDir = _path.default.resolve(cwd, 'src/migrations');
|
123
|
+
const distDir = _path.default.resolve(cwd, 'dist/migrations');
|
124
|
+
const relativeMigrations = _path.default.resolve(cwd, 'migrations');
|
125
|
+
// Use arg if provided
|
126
|
+
if (migrationDir) return migrationDir;
|
127
|
+
// Check other common locations
|
128
|
+
if (_fs.default.existsSync(srcDir)) {
|
129
|
+
return srcDir;
|
130
|
+
}
|
131
|
+
if (_fs.default.existsSync(distDir)) {
|
132
|
+
return distDir;
|
133
|
+
}
|
134
|
+
if (_fs.default.existsSync(relativeMigrations)) {
|
135
|
+
return relativeMigrations;
|
136
|
+
}
|
137
|
+
return srcDir;
|
138
|
+
}
|
106
139
|
|
107
|
-
//# sourceMappingURL=data:application/json;base64,
|
140
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../src/index.ts"],"sourcesContent":["import type { Payload } from 'payload'\n\nimport fs from 'fs'\nimport path from 'path'\nimport { createDatabaseAdapter } from 'payload/database'\n\nimport type { Args, PostgresAdapter, PostgresAdapterResult } from './types'\n\nimport { connect } from './connect'\nimport { create } from './create'\nimport { createGlobal } from './createGlobal'\nimport { createGlobalVersion } from './createGlobalVersion'\nimport { createMigration } from './createMigration'\nimport { createVersion } from './createVersion'\nimport { deleteMany } from './deleteMany'\nimport { deleteOne } from './deleteOne'\nimport { deleteVersions } from './deleteVersions'\nimport { destroy } from './destroy'\nimport { extendViteConfig } from './extendViteConfig'\nimport { extendWebpackConfig } from './extendWebpackConfig'\nimport { find } from './find'\nimport { findGlobal } from './findGlobal'\nimport { findGlobalVersions } from './findGlobalVersions'\nimport { findOne } from './findOne'\nimport { findVersions } from './findVersions'\nimport { init } from './init'\nimport { migrate } from './migrate'\nimport { migrateDown } from './migrateDown'\nimport { migrateFresh } from './migrateFresh'\nimport { migrateRefresh } from './migrateRefresh'\nimport { migrateReset } from './migrateReset'\nimport { migrateStatus } from './migrateStatus'\nimport { queryDrafts } from './queryDrafts'\nimport { beginTransaction } from './transactions/beginTransaction'\nimport { commitTransaction } from './transactions/commitTransaction'\nimport { rollbackTransaction } from './transactions/rollbackTransaction'\nimport { updateOne } from './update'\nimport { updateGlobal } from './updateGlobal'\nimport { updateGlobalVersion } from './updateGlobalVersion'\nimport { updateVersion } from './updateVersion'\n\nexport type { MigrateDownArgs, MigrateUpArgs } from './types'\n\nexport function postgresAdapter(args: Args): PostgresAdapterResult {\n  function adapter({ payload }: { payload: Payload }) {\n    const migrationDir = findMigrationDir(args.migrationDir)\n\n    extendWebpackConfig(payload.config)\n    extendViteConfig(payload.config)\n\n    return createDatabaseAdapter<PostgresAdapter>({\n      name: 'postgres',\n\n      // Postgres-specific\n      drizzle: undefined,\n      enums: {},\n      fieldConstraints: {},\n      pool: undefined,\n      poolOptions: args.pool,\n      push: args.push,\n      relations: {},\n      schema: {},\n      sessions: {},\n      tables: {},\n\n      // DatabaseAdapter\n      beginTransaction,\n      commitTransaction,\n      connect,\n      create,\n      createGlobal,\n      createGlobalVersion,\n      createMigration,\n      createVersion,\n      defaultIDType: 'number',\n      deleteMany,\n      deleteOne,\n      deleteVersions,\n      destroy,\n      find,\n      findGlobal,\n      findGlobalVersions,\n      findOne,\n      findVersions,\n      init,\n      migrate,\n      migrateDown,\n      migrateFresh,\n      migrateRefresh,\n      migrateReset,\n      migrateStatus,\n      migrationDir,\n      payload,\n      queryDrafts,\n      rollbackTransaction,\n      updateGlobal,\n      updateGlobalVersion,\n      updateOne,\n      updateVersion,\n    })\n  }\n\n  return adapter\n}\n\n/**\n * Attempt to find migrations directory.\n *\n * Checks for the following directories in order:\n * - `migrationDir` argument from Payload config\n * - `src/migrations`\n * - `dist/migrations`\n * - `migrations`\n *\n * Defaults to `src/migrations`\n *\n * @param migrationDir\n * @returns\n */\nfunction findMigrationDir(migrationDir?: string): string {\n  const cwd = process.cwd()\n  const srcDir = path.resolve(cwd, 'src/migrations')\n  const distDir = path.resolve(cwd, 'dist/migrations')\n  const relativeMigrations = path.resolve(cwd, 'migrations')\n\n  // Use arg if provided\n  if (migrationDir) return migrationDir\n\n  // Check other common locations\n  if (fs.existsSync(srcDir)) {\n    return srcDir\n  }\n\n  if (fs.existsSync(distDir)) {\n    return distDir\n  }\n\n  if (fs.existsSync(relativeMigrations)) {\n    return relativeMigrations\n  }\n\n  return srcDir\n}\n"],"names":["postgresAdapter","args","adapter","payload","migrationDir","findMigrationDir","extendWebpackConfig","config","extendViteConfig","createDatabaseAdapter","name","drizzle","undefined","enums","fieldConstraints","pool","poolOptions","push","relations","schema","sessions","tables","beginTransaction","commitTransaction","connect","create","createGlobal","createGlobalVersion","createMigration","createVersion","defaultIDType","deleteMany","deleteOne","deleteVersions","destroy","find","findGlobal","findGlobalVersions","findOne","findVersions","init","migrate","migrateDown","migrateFresh","migrateRefresh","migrateReset","migrateStatus","queryDrafts","rollbackTransaction","updateGlobal","updateGlobalVersion","updateOne","updateVersion","cwd","process","srcDir","path","resolve","distDir","relativeMigrations","fs","existsSync"],"mappings":";;;;+BA2CgBA;;;eAAAA;;;2DAzCD;6DACE;0BACqB;yBAId;wBACD;8BACM;qCACO;iCACJ;+BACF;4BACH;2BACD;gCACK;yBACP;kCACS;qCACG;sBACf;4BACM;oCACQ;yBACX;8BACK;sBACR;yBACG;6BACI;8BACC;gCACE;8BACF;+BACC;6BACF;kCACK;mCACC;qCACE;wBACV;8BACG;qCACO;+BACN;;;;;;AAIvB,SAASA,gBAAgBC,IAAU;IACxC,SAASC,QAAQ,EAAEC,OAAO,EAAwB;QAChD,MAAMC,eAAeC,iBAAiBJ,KAAKG,YAAY;QAEvDE,IAAAA,wCAAmB,EAACH,QAAQI,MAAM;QAClCC,IAAAA,kCAAgB,EAACL,QAAQI,MAAM;QAE/B,OAAOE,IAAAA,+BAAqB,EAAkB;YAC5CC,MAAM;YAEN,oBAAoB;YACpBC,SAASC;YACTC,OAAO,CAAC;YACRC,kBAAkB,CAAC;YACnBC,MAAMH;YACNI,aAAaf,KAAKc,IAAI;YACtBE,MAAMhB,KAAKgB,IAAI;YACfC,WAAW,CAAC;YACZC,QAAQ,CAAC;YACTC,UAAU,CAAC;YACXC,QAAQ,CAAC;YAET,kBAAkB;YAClBC,kBAAAA,kCAAgB;YAChBC,mBAAAA,oCAAiB;YACjBC,SAAAA,gBAAO;YACPC,QAAAA,cAAM;YACNC,cAAAA,0BAAY;YACZC,qBAAAA,wCAAmB;YACnBC,iBAAAA,gCAAe;YACfC,eAAAA,4BAAa;YACbC,eAAe;YACfC,YAAAA,sBAAU;YACVC,WAAAA,oBAAS;YACTC,gBAAAA,8BAAc;YACdC,SAAAA,gBAAO;YACPC,MAAAA,UAAI;YACJC,YAAAA,sBAAU;YACVC,oBAAAA,sCAAkB;YAClBC,SAAAA,gBAAO;YACPC,cAAAA,0BAAY;YACZC,MAAAA,UAAI;YACJC,SAAAA,gBAAO;YACPC,aAAAA,wBAAW;YACXC,cAAAA,0BAAY;YACZC,gBAAAA,8BAAc;YACdC,cAAAA,0BAAY;YACZC,eAAAA,4BAAa;YACb1C;YACAD;YACA4C,aAAAA,wBAAW;YACXC,qBAAAA,wCAAmB;YACnBC,cAAAA,0BAAY;YACZC,qBAAAA,wCAAmB;YACnBC,WAAAA,iBAAS;YACTC,eAAAA,4BAAa;QACf;IACF;IAEA,OAAOlD;AACT;AAEA;;;;;;;;;;;;;CAaC,GACD,SAASG,iBAAiBD,YAAqB;IAC7C,MAAMiD,MAAMC,QAAQD,GAAG;IACvB,MAAME,SAASC,aAAI,CAACC,OAAO,CAACJ,KAAK;IACjC,MAAMK,UAAUF,aAAI,CAACC,OAAO,CAACJ,KAAK;IAClC,MAAMM,qBAAqBH,aAAI,CAACC,OAAO,CAACJ,KAAK;IAE7C,sBAAsB;IACtB,IAAIjD,cAAc,OAAOA;IAEzB,+BAA+B;IAC/B,IAAIwD,WAAE,CAACC,UAAU,CAACN,SAAS;QACzB,OAAOA;IACT;IAEA,IAAIK,WAAE,CAACC,UAAU,CAACH,UAAU;QAC1B,OAAOA;IACT;IAEA,IAAIE,WAAE,CAACC,UAAU,CAACF,qBAAqB;QACrC,OAAOA;IACT;IAEA,OAAOJ;AACT"}
|
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"file":"getTableColumnFromPath.d.ts","sourceRoot":"","sources":["../../src/queries/getTableColumnFromPath.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,GAAG,EAAE,MAAM,aAAa,CAAA;AACtC,OAAO,KAAK,EAAE,KAAK,EAAE,kBAAkB,EAAE,UAAU,EAAE,MAAM,eAAe,CAAA;AAU1E,OAAO,KAAK,EAAE,aAAa,EAAE,YAAY,EAAE,eAAe,EAAE,MAAM,UAAU,CAAA;AAC5E,OAAO,KAAK,EAAE,qBAAqB,EAAE,eAAe,EAAE,MAAM,cAAc,CAAA;AAE1E,KAAK,UAAU,GAAG;IAChB,UAAU,EAAE,MAAM,CAAA;IAClB,KAAK,EAAE,YAAY,CAAA;IACnB,KAAK,EAAE,OAAO,CAAA;CACf,CAAA;AAED,KAAK,WAAW,GAAG;IACjB,UAAU,CAAC,EAAE,MAAM,CAAA;IACnB,WAAW,EAAE,UAAU,EAAE,CAAA;IACzB,KAAK,EAAE,kBAAkB,CAAA;IACzB,uBAAuB,CAAC,EAAE,CAAC,GAAG,EAAE,OAAO,KAAK,MAAM,CAAA;IAClD,YAAY,CAAC,EAAE,MAAM,EAAE,CAAA;IACvB,SAAS,CAAC,EAAE,GAAG,CAAA;IACf,KAAK,EAAE,YAAY,CAAA;CACpB,CAAA;AAED,KAAK,IAAI,GAAG;IACV,OAAO,EAAE,eAAe,CAAA;IACxB,UAAU,CAAC,EAAE,YAAY,CAAA;IACzB,cAAc,EAAE,MAAM,CAAA;IACtB,YAAY,CAAC,EAAE,MAAM,CAAA;IACrB,cAAc,CAAC,EAAE,MAAM,CAAA;IACvB,WAAW,CAAC,EAAE,UAAU,EAAE,CAAA;IAC1B,MAAM,EAAE,CAAC,KAAK,GAAG,UAAU,CAAC,EAAE,CAAA;IAC9B,WAAW,EAAE,qBAAqB,CAAA;IAClC,KAAK,EAAE,eAAe,CAAA;IACtB,MAAM,CAAC,EAAE,MAAM,CAAA;IACf,YAAY,EAAE,MAAM,EAAE,CAAA;IACtB,aAAa,CAAC,EAAE,MAAM,CAAA;IACtB,YAAY,EAAE,MAAM,CAAC,MAAM,EAAE,aAAa,CAAC,CAAA;IAC3C,SAAS,EAAE,MAAM,CAAA;CAClB,CAAA;AACD;;;;GAIG;AACH,eAAO,MAAM,sBAAsB,mQAehC,IAAI,KAAG,
|
1
|
+
{"version":3,"file":"getTableColumnFromPath.d.ts","sourceRoot":"","sources":["../../src/queries/getTableColumnFromPath.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,GAAG,EAAE,MAAM,aAAa,CAAA;AACtC,OAAO,KAAK,EAAE,KAAK,EAAE,kBAAkB,EAAE,UAAU,EAAE,MAAM,eAAe,CAAA;AAU1E,OAAO,KAAK,EAAE,aAAa,EAAE,YAAY,EAAE,eAAe,EAAE,MAAM,UAAU,CAAA;AAC5E,OAAO,KAAK,EAAE,qBAAqB,EAAE,eAAe,EAAE,MAAM,cAAc,CAAA;AAE1E,KAAK,UAAU,GAAG;IAChB,UAAU,EAAE,MAAM,CAAA;IAClB,KAAK,EAAE,YAAY,CAAA;IACnB,KAAK,EAAE,OAAO,CAAA;CACf,CAAA;AAED,KAAK,WAAW,GAAG;IACjB,UAAU,CAAC,EAAE,MAAM,CAAA;IACnB,WAAW,EAAE,UAAU,EAAE,CAAA;IACzB,KAAK,EAAE,kBAAkB,CAAA;IACzB,uBAAuB,CAAC,EAAE,CAAC,GAAG,EAAE,OAAO,KAAK,MAAM,CAAA;IAClD,YAAY,CAAC,EAAE,MAAM,EAAE,CAAA;IACvB,SAAS,CAAC,EAAE,GAAG,CAAA;IACf,KAAK,EAAE,YAAY,CAAA;CACpB,CAAA;AAED,KAAK,IAAI,GAAG;IACV,OAAO,EAAE,eAAe,CAAA;IACxB,UAAU,CAAC,EAAE,YAAY,CAAA;IACzB,cAAc,EAAE,MAAM,CAAA;IACtB,YAAY,CAAC,EAAE,MAAM,CAAA;IACrB,cAAc,CAAC,EAAE,MAAM,CAAA;IACvB,WAAW,CAAC,EAAE,UAAU,EAAE,CAAA;IAC1B,MAAM,EAAE,CAAC,KAAK,GAAG,UAAU,CAAC,EAAE,CAAA;IAC9B,WAAW,EAAE,qBAAqB,CAAA;IAClC,KAAK,EAAE,eAAe,CAAA;IACtB,MAAM,CAAC,EAAE,MAAM,CAAA;IACf,YAAY,EAAE,MAAM,EAAE,CAAA;IACtB,aAAa,CAAC,EAAE,MAAM,CAAA;IACtB,YAAY,EAAE,MAAM,CAAC,MAAM,EAAE,aAAa,CAAC,CAAA;IAC3C,SAAS,EAAE,MAAM,CAAA;CAClB,CAAA;AACD;;;;GAIG;AACH,eAAO,MAAM,sBAAsB,mQAehC,IAAI,KAAG,WAmXT,CAAA"}
|
@@ -233,6 +233,9 @@ const getTableColumnFromPath = ({ adapter, aliasTable, collectionPath, columnPre
|
|
233
233
|
table: adapter.tables[newTableName]
|
234
234
|
};
|
235
235
|
}
|
236
|
+
if (pathSegments[1] === 'blockType') {
|
237
|
+
throw new _errors.APIError('Querying on blockType is not supported');
|
238
|
+
}
|
236
239
|
break;
|
237
240
|
}
|
238
241
|
case 'relationship':
|
@@ -346,4 +349,4 @@ const getTableColumnFromPath = ({ adapter, aliasTable, collectionPath, columnPre
|
|
346
349
|
throw new _errors.APIError(`Cannot find field for path at ${fieldPath}`);
|
347
350
|
};
|
348
351
|
|
349
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../src/queries/getTableColumnFromPath.ts"],"sourcesContent":["/* eslint-disable no-param-reassign */\nimport type { SQL } from 'drizzle-orm'\nimport type { Field, FieldAffectingData, TabAsField } from 'payload/types'\n\nimport { and, eq, sql } from 'drizzle-orm'\nimport { alias } from 'drizzle-orm/pg-core'\nimport { APIError } from 'payload/errors'\nimport { fieldAffectsData, tabHasName } from 'payload/types'\nimport { flattenTopLevelFields } from 'payload/utilities'\nimport toSnakeCase from 'to-snake-case'\nimport { v4 as uuid } from 'uuid'\n\nimport type { GenericColumn, GenericTable, PostgresAdapter } from '../types'\nimport type { BuildQueryJoinAliases, BuildQueryJoins } from './buildQuery'\n\ntype Constraint = {\n  columnName: string\n  table: GenericTable\n  value: unknown\n}\n\ntype TableColumn = {\n  columnName?: string\n  constraints: Constraint[]\n  field: FieldAffectingData\n  getNotNullColumnByValue?: (val: unknown) => string\n  pathSegments?: string[]\n  rawColumn?: SQL\n  table: GenericTable\n}\n\ntype Args = {\n  adapter: PostgresAdapter\n  aliasTable?: GenericTable\n  collectionPath: string\n  columnPrefix?: string\n  constraintPath?: string\n  constraints?: Constraint[]\n  fields: (Field | TabAsField)[]\n  joinAliases: BuildQueryJoinAliases\n  joins: BuildQueryJoins\n  locale?: string\n  pathSegments: string[]\n  rootTableName?: string\n  selectFields: Record<string, GenericColumn>\n  tableName: string\n}\n/**\n * Transforms path to table and column name\n * Adds tables to `join`\n * @returns TableColumn\n */\nexport const getTableColumnFromPath = ({\n  adapter,\n  aliasTable,\n  collectionPath,\n  columnPrefix = '',\n  constraintPath: incomingConstraintPath,\n  constraints = [],\n  fields,\n  joinAliases,\n  joins,\n  locale: incomingLocale,\n  pathSegments: incomingSegments,\n  rootTableName: incomingRootTableName,\n  selectFields,\n  tableName,\n}: Args): TableColumn => {\n  const fieldPath = incomingSegments[0]\n  let locale = incomingLocale\n  const rootTableName = incomingRootTableName || tableName\n  let constraintPath = incomingConstraintPath || ''\n\n  const field = flattenTopLevelFields(fields as Field[]).find(\n    (fieldToFind) => fieldAffectsData(fieldToFind) && fieldToFind.name === fieldPath,\n  ) as Field | TabAsField\n  let newTableName = tableName\n\n  if (!field && fieldPath === 'id') {\n    selectFields.id = adapter.tables[newTableName].id\n    return {\n      columnName: 'id',\n      constraints,\n      field: {\n        name: 'id',\n        type: 'number',\n      },\n      table: adapter.tables[newTableName],\n    }\n  }\n\n  if (field) {\n    const pathSegments = [...incomingSegments]\n\n    // If next segment is a locale,\n    // we need to take it out and use it as the locale from this point on\n    if ('localized' in field && field.localized && adapter.payload.config.localization) {\n      const matchedLocale = adapter.payload.config.localization.localeCodes.find(\n        (locale) => locale === pathSegments[1],\n      )\n\n      if (matchedLocale) {\n        locale = matchedLocale\n        pathSegments.splice(1, 1)\n      }\n    }\n\n    switch (field.type) {\n      case 'tabs': {\n        return getTableColumnFromPath({\n          adapter,\n          aliasTable,\n          collectionPath,\n          columnPrefix,\n          constraintPath,\n          constraints,\n          fields: field.tabs.map((tab) => ({\n            ...tab,\n            type: 'tab',\n          })),\n          joinAliases,\n          joins,\n          locale,\n          pathSegments: pathSegments.slice(1),\n          rootTableName,\n          selectFields,\n          tableName: newTableName,\n        })\n      }\n      case 'tab': {\n        if (tabHasName(field)) {\n          return getTableColumnFromPath({\n            adapter,\n            aliasTable,\n            collectionPath,\n            columnPrefix: `${columnPrefix}${field.name}_`,\n            constraintPath,\n            constraints,\n            fields: field.fields,\n            joinAliases,\n            joins,\n            locale,\n            pathSegments: pathSegments.slice(1),\n            rootTableName,\n            selectFields,\n            tableName: newTableName,\n          })\n        }\n        return getTableColumnFromPath({\n          adapter,\n          aliasTable,\n          collectionPath,\n          columnPrefix,\n          constraintPath,\n          constraints,\n          fields: field.fields,\n          joinAliases,\n          joins,\n          locale,\n          pathSegments: pathSegments.slice(1),\n          rootTableName,\n          selectFields,\n          tableName: newTableName,\n        })\n      }\n\n      case 'group': {\n        if (locale && field.localized && adapter.payload.config.localization) {\n          newTableName = `${tableName}_locales`\n\n          joins[tableName] = eq(\n            adapter.tables[tableName].id,\n            adapter.tables[newTableName]._parentID,\n          )\n          if (locale !== 'all') {\n            constraints.push({\n              columnName: '_locale',\n              table: adapter.tables[newTableName],\n              value: locale,\n            })\n          }\n        }\n        return getTableColumnFromPath({\n          adapter,\n          aliasTable,\n          collectionPath,\n          columnPrefix: `${columnPrefix}${field.name}_`,\n          constraintPath,\n          constraints,\n          fields: field.fields,\n          joinAliases,\n          joins,\n          locale,\n          pathSegments: pathSegments.slice(1),\n          rootTableName,\n          selectFields,\n          tableName: newTableName,\n        })\n      }\n\n      case 'array': {\n        newTableName = `${tableName}_${toSnakeCase(field.name)}`\n        constraintPath = `${constraintPath}${field.name}.%.`\n        if (locale && field.localized && adapter.payload.config.localization) {\n          joins[newTableName] = and(\n            eq(adapter.tables[tableName].id, adapter.tables[newTableName]._parentID),\n            eq(adapter.tables[newTableName]._locale, locale),\n          )\n          if (locale !== 'all') {\n            constraints.push({\n              columnName: '_locale',\n              table: adapter.tables[newTableName],\n              value: locale,\n            })\n          }\n        } else {\n          joins[newTableName] = eq(\n            adapter.tables[tableName].id,\n            adapter.tables[newTableName]._parentID,\n          )\n        }\n        return getTableColumnFromPath({\n          adapter,\n          collectionPath,\n          constraintPath,\n          constraints,\n          fields: field.fields,\n          joinAliases,\n          joins,\n          locale,\n          pathSegments: pathSegments.slice(1),\n          rootTableName,\n          selectFields,\n          tableName: newTableName,\n        })\n      }\n\n      case 'blocks': {\n        let blockTableColumn: TableColumn\n        let newTableName: string\n        const hasBlockField = field.blocks.some((block) => {\n          newTableName = `${tableName}_blocks_${toSnakeCase(block.slug)}`\n          let result\n          const blockConstraints = []\n          const blockSelectFields = {}\n          try {\n            result = getTableColumnFromPath({\n              adapter,\n              collectionPath,\n              constraintPath: '',\n              constraints: blockConstraints,\n              fields: block.fields,\n              joinAliases,\n              joins,\n              locale,\n              pathSegments: pathSegments.slice(1),\n              rootTableName,\n              selectFields: blockSelectFields,\n              tableName: newTableName,\n            })\n          } catch (error) {\n            // this is fine, not every block will have the field\n          }\n          if (!result) {\n            return\n          }\n          blockTableColumn = result\n          constraints = constraints.concat(blockConstraints)\n          selectFields = { ...selectFields, ...blockSelectFields }\n          if (field.localized && adapter.payload.config.localization) {\n            joins[newTableName] = and(\n              eq(adapter.tables[tableName].id, adapter.tables[newTableName]._parentID),\n              eq(adapter.tables[newTableName]._locale, locale),\n            )\n            if (locale) {\n              constraints.push({\n                columnName: '_locale',\n                table: adapter.tables[newTableName],\n                value: locale,\n              })\n            }\n          } else {\n            joins[newTableName] = eq(\n              adapter.tables[tableName].id,\n              adapter.tables[newTableName]._parentID,\n            )\n          }\n          return result\n        })\n        if (hasBlockField) {\n          return {\n            columnName: blockTableColumn.columnName,\n            constraints,\n            field: blockTableColumn.field,\n            pathSegments: pathSegments.slice(1),\n            rawColumn: blockTableColumn.rawColumn,\n            table: adapter.tables[newTableName],\n          }\n        }\n        break\n      }\n\n      case 'relationship':\n      case 'upload': {\n        let relationshipFields\n        const relationTableName = `${rootTableName}_rels`\n        const newCollectionPath = pathSegments.slice(1).join('.')\n        const aliasRelationshipTableName = uuid()\n        const aliasRelationshipTable = alias(\n          adapter.tables[relationTableName],\n          aliasRelationshipTableName,\n        )\n\n        // Join in the relationships table\n        joinAliases.push({\n          condition: eq(\n            (aliasTable || adapter.tables[rootTableName]).id,\n            aliasRelationshipTable.parent,\n          ),\n          table: aliasRelationshipTable,\n        })\n\n        selectFields[`${relationTableName}.path`] = aliasRelationshipTable.path\n\n        constraints.push({\n          columnName: 'path',\n          table: aliasRelationshipTable,\n          value: `${constraintPath}${field.name}`,\n        })\n\n        let newAliasTable\n\n        if (typeof field.relationTo === 'string') {\n          newTableName = `${toSnakeCase(field.relationTo)}`\n          // parent to relationship join table\n          relationshipFields = adapter.payload.collections[field.relationTo].config.fields\n\n          newAliasTable = alias(adapter.tables[newTableName], toSnakeCase(uuid()))\n\n          joinAliases.push({\n            condition: eq(newAliasTable.id, aliasRelationshipTable[`${field.relationTo}ID`]),\n            table: newAliasTable,\n          })\n\n          if (newCollectionPath === '') {\n            return {\n              columnName: `${field.relationTo}ID`,\n              constraints,\n              field,\n              table: aliasRelationshipTable,\n            }\n          }\n        } else if (newCollectionPath === 'value') {\n          const tableColumnsNames = field.relationTo.map(\n            (relationTo) => `\"${aliasRelationshipTableName}\".\"${toSnakeCase(relationTo)}_id\"`,\n          )\n          return {\n            constraints,\n            field,\n            rawColumn: sql.raw(`COALESCE(${tableColumnsNames.join(', ')})`),\n            table: aliasRelationshipTable,\n          }\n        } else if (newCollectionPath === 'relationTo') {\n          const relationTo = Array.isArray(field.relationTo) ? field.relationTo : [field.relationTo]\n\n          return {\n            constraints,\n            field,\n            getNotNullColumnByValue: (val) => {\n              const matchedRelation = relationTo.find((relation) => relation === val)\n              if (matchedRelation) return `${matchedRelation}ID`\n              return undefined\n            },\n            table: aliasRelationshipTable,\n          }\n        } else {\n          throw new APIError('Not supported')\n        }\n\n        return getTableColumnFromPath({\n          adapter,\n          aliasTable: newAliasTable,\n          collectionPath: newCollectionPath,\n          constraints,\n          fields: relationshipFields,\n          joinAliases,\n          joins,\n          locale,\n          pathSegments: pathSegments.slice(1),\n          rootTableName: newTableName,\n          selectFields,\n          tableName: newTableName,\n        })\n      }\n\n      default: {\n        if (fieldAffectsData(field)) {\n          if (field.localized && adapter.payload.config.localization) {\n            // If localized, we go to localized table and set aliasTable to undefined\n            // so it is not picked up below to be used as targetTable\n            newTableName = `${tableName}_locales`\n\n            const parentTable = aliasTable || adapter.tables[tableName]\n\n            joins[newTableName] = eq(parentTable.id, adapter.tables[newTableName]._parentID)\n\n            aliasTable = undefined\n\n            if (locale !== 'all') {\n              constraints.push({\n                columnName: '_locale',\n                table: adapter.tables[newTableName],\n                value: locale,\n              })\n            }\n          }\n\n          const targetTable = aliasTable || adapter.tables[newTableName]\n\n          selectFields[`${newTableName}.${columnPrefix}${field.name}`] =\n            targetTable[`${columnPrefix}${field.name}`]\n\n          return {\n            columnName: `${columnPrefix}${field.name}`,\n            constraints,\n            field,\n            pathSegments: pathSegments,\n            table: targetTable,\n          }\n        }\n      }\n    }\n  }\n\n  throw new APIError(`Cannot find field for path at ${fieldPath}`)\n}\n"],"names":["getTableColumnFromPath","adapter","aliasTable","collectionPath","columnPrefix","constraintPath","incomingConstraintPath","constraints","fields","joinAliases","joins","locale","incomingLocale","pathSegments","incomingSegments","rootTableName","incomingRootTableName","selectFields","tableName","fieldPath","field","flattenTopLevelFields","find","fieldToFind","fieldAffectsData","name","newTableName","id","tables","columnName","type","table","localized","payload","config","localization","matchedLocale","localeCodes","splice","tabs","map","tab","slice","tabHasName","eq","_parentID","push","value","toSnakeCase","and","_locale","blockTableColumn","hasBlockField","blocks","some","block","slug","result","blockConstraints","blockSelectFields","error","concat","rawColumn","relationshipFields","relationTableName","newCollectionPath","join","aliasRelationshipTableName","uuid","aliasRelationshipTable","alias","condition","parent","path","newAliasTable","relationTo","collections","tableColumnsNames","sql","raw","Array","isArray","getNotNullColumnByValue","val","matchedRelation","relation","undefined","APIError","parentTable","targetTable"],"mappings":"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"}
|
352
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../src/queries/getTableColumnFromPath.ts"],"sourcesContent":["/* eslint-disable no-param-reassign */\nimport type { SQL } from 'drizzle-orm'\nimport type { Field, FieldAffectingData, TabAsField } from 'payload/types'\n\nimport { and, eq, sql } from 'drizzle-orm'\nimport { alias } from 'drizzle-orm/pg-core'\nimport { APIError } from 'payload/errors'\nimport { fieldAffectsData, tabHasName } from 'payload/types'\nimport { flattenTopLevelFields } from 'payload/utilities'\nimport toSnakeCase from 'to-snake-case'\nimport { v4 as uuid } from 'uuid'\n\nimport type { GenericColumn, GenericTable, PostgresAdapter } from '../types'\nimport type { BuildQueryJoinAliases, BuildQueryJoins } from './buildQuery'\n\ntype Constraint = {\n  columnName: string\n  table: GenericTable\n  value: unknown\n}\n\ntype TableColumn = {\n  columnName?: string\n  constraints: Constraint[]\n  field: FieldAffectingData\n  getNotNullColumnByValue?: (val: unknown) => string\n  pathSegments?: string[]\n  rawColumn?: SQL\n  table: GenericTable\n}\n\ntype Args = {\n  adapter: PostgresAdapter\n  aliasTable?: GenericTable\n  collectionPath: string\n  columnPrefix?: string\n  constraintPath?: string\n  constraints?: Constraint[]\n  fields: (Field | TabAsField)[]\n  joinAliases: BuildQueryJoinAliases\n  joins: BuildQueryJoins\n  locale?: string\n  pathSegments: string[]\n  rootTableName?: string\n  selectFields: Record<string, GenericColumn>\n  tableName: string\n}\n/**\n * Transforms path to table and column name\n * Adds tables to `join`\n * @returns TableColumn\n */\nexport const getTableColumnFromPath = ({\n  adapter,\n  aliasTable,\n  collectionPath,\n  columnPrefix = '',\n  constraintPath: incomingConstraintPath,\n  constraints = [],\n  fields,\n  joinAliases,\n  joins,\n  locale: incomingLocale,\n  pathSegments: incomingSegments,\n  rootTableName: incomingRootTableName,\n  selectFields,\n  tableName,\n}: Args): TableColumn => {\n  const fieldPath = incomingSegments[0]\n  let locale = incomingLocale\n  const rootTableName = incomingRootTableName || tableName\n  let constraintPath = incomingConstraintPath || ''\n\n  const field = flattenTopLevelFields(fields as Field[]).find(\n    (fieldToFind) => fieldAffectsData(fieldToFind) && fieldToFind.name === fieldPath,\n  ) as Field | TabAsField\n  let newTableName = tableName\n\n  if (!field && fieldPath === 'id') {\n    selectFields.id = adapter.tables[newTableName].id\n    return {\n      columnName: 'id',\n      constraints,\n      field: {\n        name: 'id',\n        type: 'number',\n      },\n      table: adapter.tables[newTableName],\n    }\n  }\n\n  if (field) {\n    const pathSegments = [...incomingSegments]\n\n    // If next segment is a locale,\n    // we need to take it out and use it as the locale from this point on\n    if ('localized' in field && field.localized && adapter.payload.config.localization) {\n      const matchedLocale = adapter.payload.config.localization.localeCodes.find(\n        (locale) => locale === pathSegments[1],\n      )\n\n      if (matchedLocale) {\n        locale = matchedLocale\n        pathSegments.splice(1, 1)\n      }\n    }\n\n    switch (field.type) {\n      case 'tabs': {\n        return getTableColumnFromPath({\n          adapter,\n          aliasTable,\n          collectionPath,\n          columnPrefix,\n          constraintPath,\n          constraints,\n          fields: field.tabs.map((tab) => ({\n            ...tab,\n            type: 'tab',\n          })),\n          joinAliases,\n          joins,\n          locale,\n          pathSegments: pathSegments.slice(1),\n          rootTableName,\n          selectFields,\n          tableName: newTableName,\n        })\n      }\n      case 'tab': {\n        if (tabHasName(field)) {\n          return getTableColumnFromPath({\n            adapter,\n            aliasTable,\n            collectionPath,\n            columnPrefix: `${columnPrefix}${field.name}_`,\n            constraintPath,\n            constraints,\n            fields: field.fields,\n            joinAliases,\n            joins,\n            locale,\n            pathSegments: pathSegments.slice(1),\n            rootTableName,\n            selectFields,\n            tableName: newTableName,\n          })\n        }\n        return getTableColumnFromPath({\n          adapter,\n          aliasTable,\n          collectionPath,\n          columnPrefix,\n          constraintPath,\n          constraints,\n          fields: field.fields,\n          joinAliases,\n          joins,\n          locale,\n          pathSegments: pathSegments.slice(1),\n          rootTableName,\n          selectFields,\n          tableName: newTableName,\n        })\n      }\n\n      case 'group': {\n        if (locale && field.localized && adapter.payload.config.localization) {\n          newTableName = `${tableName}_locales`\n\n          joins[tableName] = eq(\n            adapter.tables[tableName].id,\n            adapter.tables[newTableName]._parentID,\n          )\n          if (locale !== 'all') {\n            constraints.push({\n              columnName: '_locale',\n              table: adapter.tables[newTableName],\n              value: locale,\n            })\n          }\n        }\n        return getTableColumnFromPath({\n          adapter,\n          aliasTable,\n          collectionPath,\n          columnPrefix: `${columnPrefix}${field.name}_`,\n          constraintPath,\n          constraints,\n          fields: field.fields,\n          joinAliases,\n          joins,\n          locale,\n          pathSegments: pathSegments.slice(1),\n          rootTableName,\n          selectFields,\n          tableName: newTableName,\n        })\n      }\n\n      case 'array': {\n        newTableName = `${tableName}_${toSnakeCase(field.name)}`\n        constraintPath = `${constraintPath}${field.name}.%.`\n        if (locale && field.localized && adapter.payload.config.localization) {\n          joins[newTableName] = and(\n            eq(adapter.tables[tableName].id, adapter.tables[newTableName]._parentID),\n            eq(adapter.tables[newTableName]._locale, locale),\n          )\n          if (locale !== 'all') {\n            constraints.push({\n              columnName: '_locale',\n              table: adapter.tables[newTableName],\n              value: locale,\n            })\n          }\n        } else {\n          joins[newTableName] = eq(\n            adapter.tables[tableName].id,\n            adapter.tables[newTableName]._parentID,\n          )\n        }\n        return getTableColumnFromPath({\n          adapter,\n          collectionPath,\n          constraintPath,\n          constraints,\n          fields: field.fields,\n          joinAliases,\n          joins,\n          locale,\n          pathSegments: pathSegments.slice(1),\n          rootTableName,\n          selectFields,\n          tableName: newTableName,\n        })\n      }\n\n      case 'blocks': {\n        let blockTableColumn: TableColumn\n        let newTableName: string\n        const hasBlockField = field.blocks.some((block) => {\n          newTableName = `${tableName}_blocks_${toSnakeCase(block.slug)}`\n          let result\n          const blockConstraints = []\n          const blockSelectFields = {}\n          try {\n            result = getTableColumnFromPath({\n              adapter,\n              collectionPath,\n              constraintPath: '',\n              constraints: blockConstraints,\n              fields: block.fields,\n              joinAliases,\n              joins,\n              locale,\n              pathSegments: pathSegments.slice(1),\n              rootTableName,\n              selectFields: blockSelectFields,\n              tableName: newTableName,\n            })\n          } catch (error) {\n            // this is fine, not every block will have the field\n          }\n          if (!result) {\n            return\n          }\n          blockTableColumn = result\n          constraints = constraints.concat(blockConstraints)\n          selectFields = { ...selectFields, ...blockSelectFields }\n          if (field.localized && adapter.payload.config.localization) {\n            joins[newTableName] = and(\n              eq(adapter.tables[tableName].id, adapter.tables[newTableName]._parentID),\n              eq(adapter.tables[newTableName]._locale, locale),\n            )\n            if (locale) {\n              constraints.push({\n                columnName: '_locale',\n                table: adapter.tables[newTableName],\n                value: locale,\n              })\n            }\n          } else {\n            joins[newTableName] = eq(\n              adapter.tables[tableName].id,\n              adapter.tables[newTableName]._parentID,\n            )\n          }\n          return result\n        })\n        if (hasBlockField) {\n          return {\n            columnName: blockTableColumn.columnName,\n            constraints,\n            field: blockTableColumn.field,\n            pathSegments: pathSegments.slice(1),\n            rawColumn: blockTableColumn.rawColumn,\n            table: adapter.tables[newTableName],\n          }\n        }\n        if (pathSegments[1] === 'blockType') {\n          throw new APIError('Querying on blockType is not supported')\n        }\n        break\n      }\n\n      case 'relationship':\n      case 'upload': {\n        let relationshipFields\n        const relationTableName = `${rootTableName}_rels`\n        const newCollectionPath = pathSegments.slice(1).join('.')\n        const aliasRelationshipTableName = uuid()\n        const aliasRelationshipTable = alias(\n          adapter.tables[relationTableName],\n          aliasRelationshipTableName,\n        )\n\n        // Join in the relationships table\n        joinAliases.push({\n          condition: eq(\n            (aliasTable || adapter.tables[rootTableName]).id,\n            aliasRelationshipTable.parent,\n          ),\n          table: aliasRelationshipTable,\n        })\n\n        selectFields[`${relationTableName}.path`] = aliasRelationshipTable.path\n\n        constraints.push({\n          columnName: 'path',\n          table: aliasRelationshipTable,\n          value: `${constraintPath}${field.name}`,\n        })\n\n        let newAliasTable\n\n        if (typeof field.relationTo === 'string') {\n          newTableName = `${toSnakeCase(field.relationTo)}`\n          // parent to relationship join table\n          relationshipFields = adapter.payload.collections[field.relationTo].config.fields\n\n          newAliasTable = alias(adapter.tables[newTableName], toSnakeCase(uuid()))\n\n          joinAliases.push({\n            condition: eq(newAliasTable.id, aliasRelationshipTable[`${field.relationTo}ID`]),\n            table: newAliasTable,\n          })\n\n          if (newCollectionPath === '') {\n            return {\n              columnName: `${field.relationTo}ID`,\n              constraints,\n              field,\n              table: aliasRelationshipTable,\n            }\n          }\n        } else if (newCollectionPath === 'value') {\n          const tableColumnsNames = field.relationTo.map(\n            (relationTo) => `\"${aliasRelationshipTableName}\".\"${toSnakeCase(relationTo)}_id\"`,\n          )\n          return {\n            constraints,\n            field,\n            rawColumn: sql.raw(`COALESCE(${tableColumnsNames.join(', ')})`),\n            table: aliasRelationshipTable,\n          }\n        } else if (newCollectionPath === 'relationTo') {\n          const relationTo = Array.isArray(field.relationTo) ? field.relationTo : [field.relationTo]\n\n          return {\n            constraints,\n            field,\n            getNotNullColumnByValue: (val) => {\n              const matchedRelation = relationTo.find((relation) => relation === val)\n              if (matchedRelation) return `${matchedRelation}ID`\n              return undefined\n            },\n            table: aliasRelationshipTable,\n          }\n        } else {\n          throw new APIError('Not supported')\n        }\n\n        return getTableColumnFromPath({\n          adapter,\n          aliasTable: newAliasTable,\n          collectionPath: newCollectionPath,\n          constraints,\n          fields: relationshipFields,\n          joinAliases,\n          joins,\n          locale,\n          pathSegments: pathSegments.slice(1),\n          rootTableName: newTableName,\n          selectFields,\n          tableName: newTableName,\n        })\n      }\n\n      default: {\n        if (fieldAffectsData(field)) {\n          if (field.localized && adapter.payload.config.localization) {\n            // If localized, we go to localized table and set aliasTable to undefined\n            // so it is not picked up below to be used as targetTable\n            newTableName = `${tableName}_locales`\n\n            const parentTable = aliasTable || adapter.tables[tableName]\n\n            joins[newTableName] = eq(parentTable.id, adapter.tables[newTableName]._parentID)\n\n            aliasTable = undefined\n\n            if (locale !== 'all') {\n              constraints.push({\n                columnName: '_locale',\n                table: adapter.tables[newTableName],\n                value: locale,\n              })\n            }\n          }\n\n          const targetTable = aliasTable || adapter.tables[newTableName]\n\n          selectFields[`${newTableName}.${columnPrefix}${field.name}`] =\n            targetTable[`${columnPrefix}${field.name}`]\n\n          return {\n            columnName: `${columnPrefix}${field.name}`,\n            constraints,\n            field,\n            pathSegments: pathSegments,\n            table: targetTable,\n          }\n        }\n      }\n    }\n  }\n\n  throw new APIError(`Cannot find field for path at ${fieldPath}`)\n}\n"],"names":["getTableColumnFromPath","adapter","aliasTable","collectionPath","columnPrefix","constraintPath","incomingConstraintPath","constraints","fields","joinAliases","joins","locale","incomingLocale","pathSegments","incomingSegments","rootTableName","incomingRootTableName","selectFields","tableName","fieldPath","field","flattenTopLevelFields","find","fieldToFind","fieldAffectsData","name","newTableName","id","tables","columnName","type","table","localized","payload","config","localization","matchedLocale","localeCodes","splice","tabs","map","tab","slice","tabHasName","eq","_parentID","push","value","toSnakeCase","and","_locale","blockTableColumn","hasBlockField","blocks","some","block","slug","result","blockConstraints","blockSelectFields","error","concat","rawColumn","APIError","relationshipFields","relationTableName","newCollectionPath","join","aliasRelationshipTableName","uuid","aliasRelationshipTable","alias","condition","parent","path","newAliasTable","relationTo","collections","tableColumnsNames","sql","raw","Array","isArray","getNotNullColumnByValue","val","matchedRelation","relation","undefined","parentTable","targetTable"],"mappings":"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"}
|
@@ -21,7 +21,7 @@ const insertArrays = async ({ adapter, arrays, db, parentRows })=>{
|
|
21
21
|
rows: []
|
22
22
|
};
|
23
23
|
}
|
24
|
-
const parentID = parentRows[parentRowIndex].id;
|
24
|
+
const parentID = parentRows[parentRowIndex].id || parentRows[parentRowIndex]._parentID;
|
25
25
|
// Add any sub arrays that need to be created
|
26
26
|
// We will call this recursively below
|
27
27
|
arrayRows.forEach((arrayRow)=>{
|
@@ -61,4 +61,4 @@ const insertArrays = async ({ adapter, arrays, db, parentRows })=>{
|
|
61
61
|
}
|
62
62
|
};
|
63
63
|
|
64
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy91cHNlcnRSb3cvaW5zZXJ0QXJyYXlzLnRzIl0sInNvdXJjZXNDb250ZW50IjpbIi8qIGVzbGludC1kaXNhYmxlIG5vLXBhcmFtLXJlYXNzaWduICovXG5pbXBvcnQgdHlwZSB7IEFycmF5Um93VG9JbnNlcnQgfSBmcm9tICcuLi90cmFuc2Zvcm0vd3JpdGUvdHlwZXMnXG5pbXBvcnQgdHlwZSB7IERyaXp6bGVEQiwgUG9zdGdyZXNBZGFwdGVyIH0gZnJvbSAnLi4vdHlwZXMnXG5cbnR5cGUgQXJncyA9IHtcbiAgYWRhcHRlcjogUG9zdGdyZXNBZGFwdGVyXG4gIGFycmF5czoge1xuICAgIFt0YWJsZU5hbWU6IHN0cmluZ106IEFycmF5Um93VG9JbnNlcnRbXVxuICB9W11cbiAgZGI6IERyaXp6bGVEQlxuICBwYXJlbnRSb3dzOiBSZWNvcmQ8c3RyaW5nLCB1bmtub3duPltdXG59XG5cbnR5cGUgUm93c0J5VGFibGUgPSB7XG4gIFt0YWJsZU5hbWU6IHN0cmluZ106IHtcbiAgICBhcnJheXM6IHtcbiAgICAgIFt0YWJsZU5hbWU6IHN0cmluZ106IEFycmF5Um93VG9JbnNlcnRbXVxuICAgIH1bXVxuICAgIGxvY2FsZXM6IFJlY29yZDxzdHJpbmcsIHVua25vd24+W11cbiAgICByb3dzOiBSZWNvcmQ8c3RyaW5nLCB1bmtub3duPltdXG4gIH1cbn1cblxuZXhwb3J0IGNvbnN0IGluc2VydEFycmF5cyA9IGFzeW5jICh7IGFkYXB0ZXIsIGFycmF5cywgZGIsIHBhcmVudFJvd3MgfTogQXJncyk6IFByb21pc2U8dm9pZD4gPT4ge1xuICAvLyBNYWludGFpbiBhIG1hcCBvZiBmbGF0dGVuZWQgcm93cyBieSB0YWJsZVxuICBjb25zdCByb3dzQnlUYWJsZTogUm93c0J5VGFibGUgPSB7fVxuXG4gIGFycmF5cy5mb3JFYWNoKChhcnJheXNCeVRhYmxlLCBwYXJlbnRSb3dJbmRleCkgPT4ge1xuICAgIE9iamVjdC5lbnRyaWVzKGFycmF5c0J5VGFibGUpLmZvckVhY2goKFt0YWJsZU5hbWUsIGFycmF5Um93c10pID0+
|
64
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy91cHNlcnRSb3cvaW5zZXJ0QXJyYXlzLnRzIl0sInNvdXJjZXNDb250ZW50IjpbIi8qIGVzbGludC1kaXNhYmxlIG5vLXBhcmFtLXJlYXNzaWduICovXG5pbXBvcnQgdHlwZSB7IEFycmF5Um93VG9JbnNlcnQgfSBmcm9tICcuLi90cmFuc2Zvcm0vd3JpdGUvdHlwZXMnXG5pbXBvcnQgdHlwZSB7IERyaXp6bGVEQiwgUG9zdGdyZXNBZGFwdGVyIH0gZnJvbSAnLi4vdHlwZXMnXG5cbnR5cGUgQXJncyA9IHtcbiAgYWRhcHRlcjogUG9zdGdyZXNBZGFwdGVyXG4gIGFycmF5czoge1xuICAgIFt0YWJsZU5hbWU6IHN0cmluZ106IEFycmF5Um93VG9JbnNlcnRbXVxuICB9W11cbiAgZGI6IERyaXp6bGVEQlxuICBwYXJlbnRSb3dzOiBSZWNvcmQ8c3RyaW5nLCB1bmtub3duPltdXG59XG5cbnR5cGUgUm93c0J5VGFibGUgPSB7XG4gIFt0YWJsZU5hbWU6IHN0cmluZ106IHtcbiAgICBhcnJheXM6IHtcbiAgICAgIFt0YWJsZU5hbWU6IHN0cmluZ106IEFycmF5Um93VG9JbnNlcnRbXVxuICAgIH1bXVxuICAgIGxvY2FsZXM6IFJlY29yZDxzdHJpbmcsIHVua25vd24+W11cbiAgICByb3dzOiBSZWNvcmQ8c3RyaW5nLCB1bmtub3duPltdXG4gIH1cbn1cblxuZXhwb3J0IGNvbnN0IGluc2VydEFycmF5cyA9IGFzeW5jICh7IGFkYXB0ZXIsIGFycmF5cywgZGIsIHBhcmVudFJvd3MgfTogQXJncyk6IFByb21pc2U8dm9pZD4gPT4ge1xuICAvLyBNYWludGFpbiBhIG1hcCBvZiBmbGF0dGVuZWQgcm93cyBieSB0YWJsZVxuICBjb25zdCByb3dzQnlUYWJsZTogUm93c0J5VGFibGUgPSB7fVxuXG4gIGFycmF5cy5mb3JFYWNoKChhcnJheXNCeVRhYmxlLCBwYXJlbnRSb3dJbmRleCkgPT4ge1xuICAgIE9iamVjdC5lbnRyaWVzKGFycmF5c0J5VGFibGUpLmZvckVhY2goKFt0YWJsZU5hbWUsIGFycmF5Um93c10pID0+IHtcbiAgICAgIC8vIElmIHRoZSB0YWJsZSBkb2Vzbid0IGV4aXN0IGluIG1hcCwgaW5pdGlhbGl6ZSBpdFxuICAgICAgaWYgKCFyb3dzQnlUYWJsZVt0YWJsZU5hbWVdKSB7XG4gICAgICAgIHJvd3NCeVRhYmxlW3RhYmxlTmFtZV0gPSB7XG4gICAgICAgICAgYXJyYXlzOiBbXSxcbiAgICAgICAgICBsb2NhbGVzOiBbXSxcbiAgICAgICAgICByb3dzOiBbXSxcbiAgICAgICAgfVxuICAgICAgfVxuXG4gICAgICBjb25zdCBwYXJlbnRJRCA9IHBhcmVudFJvd3NbcGFyZW50Um93SW5kZXhdLmlkIHx8IHBhcmVudFJvd3NbcGFyZW50Um93SW5kZXhdLl9wYXJlbnRJRFxuXG4gICAgICAvLyBBZGQgYW55IHN1YiBhcnJheXMgdGhhdCBuZWVkIHRvIGJlIGNyZWF0ZWRcbiAgICAgIC8vIFdlIHdpbGwgY2FsbCB0aGlzIHJlY3Vyc2l2ZWx5IGJlbG93XG4gICAgICBhcnJheVJvd3MuZm9yRWFjaCgoYXJyYXlSb3cpID0+IHtcbiAgICAgICAgaWYgKE9iamVjdC5rZXlzKGFycmF5Um93LmFycmF5cykubGVuZ3RoID4gMCkge1xuICAgICAgICAgIHJvd3NCeVRhYmxlW3RhYmxlTmFtZV0uYXJyYXlzLnB1c2goYXJyYXlSb3cuYXJyYXlzKVxuICAgICAgICB9XG5cbiAgICAgICAgLy8gU2V0IHVwIHBhcmVudCBJRHMgZm9yIGJvdGggcm93IGFuZCBsb2NhbGUgcm93XG4gICAgICAgIGFycmF5Um93LnJvdy5fcGFyZW50SUQgPSBwYXJlbnRJRFxuICAgICAgICByb3dzQnlUYWJsZVt0YWJsZU5hbWVdLnJvd3MucHVzaChhcnJheVJvdy5yb3cpXG5cbiAgICAgICAgT2JqZWN0LmVudHJpZXMoYXJyYXlSb3cubG9jYWxlcykuZm9yRWFjaCgoW2FycmF5Um93TG9jYWxlLCBhcnJheVJvd0xvY2FsZURhdGFdKSA9PiB7XG4gICAgICAgICAgYXJyYXlSb3dMb2NhbGVEYXRhLl9wYXJlbnRJRCA9IGFycmF5Um93LnJvdy5pZFxuICAgICAgICAgIGFycmF5Um93TG9jYWxlRGF0YS5fbG9jYWxlID0gYXJyYXlSb3dMb2NhbGVcbiAgICAgICAgICByb3dzQnlUYWJsZVt0YWJsZU5hbWVdLmxvY2FsZXMucHVzaChhcnJheVJvd0xvY2FsZURhdGEpXG4gICAgICAgIH0pXG4gICAgICB9KVxuICAgIH0pXG4gIH0pXG5cbiAgLy8gSW5zZXJ0IGFsbCBjb3JyZXNwb25kaW5nIGFycmF5c1xuICAvLyAob25lIGluc2VydCBwZXIgYXJyYXkgdGFibGUpXG4gIGZvciAoY29uc3QgW3RhYmxlTmFtZSwgcm93XSBvZiBPYmplY3QuZW50cmllcyhyb3dzQnlUYWJsZSkpIHtcbiAgICBpZiAocm93LnJvd3MubGVuZ3RoID4gMCkge1xuICAgICAgYXdhaXQgZGIuaW5zZXJ0KGFkYXB0ZXIudGFibGVzW3RhYmxlTmFtZV0pLnZhbHVlcyhyb3cucm93cykucmV0dXJuaW5nKClcbiAgICB9XG5cbiAgICAvLyBJbnNlcnQgbG9jYWxlIHJvd3NcbiAgICBpZiAoYWRhcHRlci50YWJsZXNbYCR7dGFibGVOYW1lfV9sb2NhbGVzYF0gJiYgcm93LmxvY2FsZXMubGVuZ3RoID4gMCkge1xuICAgICAgYXdhaXQgZGIuaW5zZXJ0KGFkYXB0ZXIudGFibGVzW2Ake3RhYmxlTmFtZX1fbG9jYWxlc2BdKS52YWx1ZXMocm93LmxvY2FsZXMpLnJldHVybmluZygpXG4gICAgfVxuXG4gICAgLy8gSWYgdGhlcmUgYXJlIHN1YiBhcnJheXMsIGNhbGwgdGhpcyBmdW5jdGlvbiByZWN1cnNpdmVseVxuICAgIGlmIChyb3cuYXJyYXlzLmxlbmd0aCA+IDApIHtcbiAgICAgIGF3YWl0IGluc2VydEFycmF5cyh7XG4gICAgICAgIGFkYXB0ZXIsXG4gICAgICAgIGFycmF5czogcm93LmFycmF5cyxcbiAgICAgICAgZGIsXG4gICAgICAgIHBhcmVudFJvd3M6IHJvdy5yb3dzLFxuICAgICAgfSlcbiAgICB9XG4gIH1cbn1cbiJdLCJuYW1lcyI6WyJpbnNlcnRBcnJheXMiLCJhZGFwdGVyIiwiYXJyYXlzIiwiZGIiLCJwYXJlbnRSb3dzIiwicm93c0J5VGFibGUiLCJmb3JFYWNoIiwiYXJyYXlzQnlUYWJsZSIsInBhcmVudFJvd0luZGV4IiwiT2JqZWN0IiwiZW50cmllcyIsInRhYmxlTmFtZSIsImFycmF5Um93cyIsImxvY2FsZXMiLCJyb3dzIiwicGFyZW50SUQiLCJpZCIsIl9wYXJlbnRJRCIsImFycmF5Um93Iiwia2V5cyIsImxlbmd0aCIsInB1c2giLCJyb3ciLCJhcnJheVJvd0xvY2FsZSIsImFycmF5Um93TG9jYWxlRGF0YSIsIl9sb2NhbGUiLCJpbnNlcnQiLCJ0YWJsZXMiLCJ2YWx1ZXMiLCJyZXR1cm5pbmciXSwibWFwcGluZ3MiOiJBQUFBLG9DQUFvQzs7OzsrQkF1QnZCQTs7O2VBQUFBOzs7QUFBTixNQUFNQSxlQUFlLE9BQU8sRUFBRUMsT0FBTyxFQUFFQyxNQUFNLEVBQUVDLEVBQUUsRUFBRUMsVUFBVSxFQUFRO0lBQzFFLDRDQUE0QztJQUM1QyxNQUFNQyxjQUEyQixDQUFDO0lBRWxDSCxPQUFPSSxPQUFPLENBQUMsQ0FBQ0MsZUFBZUM7UUFDN0JDLE9BQU9DLE9BQU8sQ0FBQ0gsZUFBZUQsT0FBTyxDQUFDLENBQUMsQ0FBQ0ssV0FBV0MsVUFBVTtZQUMzRCxtREFBbUQ7WUFDbkQsSUFBSSxDQUFDUCxXQUFXLENBQUNNLFVBQVUsRUFBRTtnQkFDM0JOLFdBQVcsQ0FBQ00sVUFBVSxHQUFHO29CQUN2QlQsUUFBUSxFQUFFO29CQUNWVyxTQUFTLEVBQUU7b0JBQ1hDLE1BQU0sRUFBRTtnQkFDVjtZQUNGO1lBRUEsTUFBTUMsV0FBV1gsVUFBVSxDQUFDSSxlQUFlLENBQUNRLEVBQUUsSUFBSVosVUFBVSxDQUFDSSxlQUFlLENBQUNTLFNBQVM7WUFFdEYsNkNBQTZDO1lBQzdDLHNDQUFzQztZQUN0Q0wsVUFBVU4sT0FBTyxDQUFDLENBQUNZO2dCQUNqQixJQUFJVCxPQUFPVSxJQUFJLENBQUNELFNBQVNoQixNQUFNLEVBQUVrQixNQUFNLEdBQUcsR0FBRztvQkFDM0NmLFdBQVcsQ0FBQ00sVUFBVSxDQUFDVCxNQUFNLENBQUNtQixJQUFJLENBQUNILFNBQVNoQixNQUFNO2dCQUNwRDtnQkFFQSxnREFBZ0Q7Z0JBQ2hEZ0IsU0FBU0ksR0FBRyxDQUFDTCxTQUFTLEdBQUdGO2dCQUN6QlYsV0FBVyxDQUFDTSxVQUFVLENBQUNHLElBQUksQ0FBQ08sSUFBSSxDQUFDSCxTQUFTSSxHQUFHO2dCQUU3Q2IsT0FBT0MsT0FBTyxDQUFDUSxTQUFTTCxPQUFPLEVBQUVQLE9BQU8sQ0FBQyxDQUFDLENBQUNpQixnQkFBZ0JDLG1CQUFtQjtvQkFDNUVBLG1CQUFtQlAsU0FBUyxHQUFHQyxTQUFTSSxHQUFHLENBQUNOLEVBQUU7b0JBQzlDUSxtQkFBbUJDLE9BQU8sR0FBR0Y7b0JBQzdCbEIsV0FBVyxDQUFDTSxVQUFVLENBQUNFLE9BQU8sQ0FBQ1EsSUFBSSxDQUFDRztnQkFDdEM7WUFDRjtRQUNGO0lBQ0Y7SUFFQSxrQ0FBa0M7SUFDbEMsK0JBQStCO0lBQy9CLEtBQUssTUFBTSxDQUFDYixXQUFXVyxJQUFJLElBQUliLE9BQU9DLE9BQU8sQ0FBQ0wsYUFBYztRQUMxRCxJQUFJaUIsSUFBSVIsSUFBSSxDQUFDTSxNQUFNLEdBQUcsR0FBRztZQUN2QixNQUFNakIsR0FBR3VCLE1BQU0sQ0FBQ3pCLFFBQVEwQixNQUFNLENBQUNoQixVQUFVLEVBQUVpQixNQUFNLENBQUNOLElBQUlSLElBQUksRUFBRWUsU0FBUztRQUN2RTtRQUVBLHFCQUFxQjtRQUNyQixJQUFJNUIsUUFBUTBCLE1BQU0sQ0FBQyxDQUFDLEVBQUVoQixVQUFVLFFBQVEsQ0FBQyxDQUFDLElBQUlXLElBQUlULE9BQU8sQ0FBQ08sTUFBTSxHQUFHLEdBQUc7WUFDcEUsTUFBTWpCLEdBQUd1QixNQUFNLENBQUN6QixRQUFRMEIsTUFBTSxDQUFDLENBQUMsRUFBRWhCLFVBQVUsUUFBUSxDQUFDLENBQUMsRUFBRWlCLE1BQU0sQ0FBQ04sSUFBSVQsT0FBTyxFQUFFZ0IsU0FBUztRQUN2RjtRQUVBLDBEQUEwRDtRQUMxRCxJQUFJUCxJQUFJcEIsTUFBTSxDQUFDa0IsTUFBTSxHQUFHLEdBQUc7WUFDekIsTUFBTXBCLGFBQWE7Z0JBQ2pCQztnQkFDQUMsUUFBUW9CLElBQUlwQixNQUFNO2dCQUNsQkM7Z0JBQ0FDLFlBQVlrQixJQUFJUixJQUFJO1lBQ3RCO1FBQ0Y7SUFDRjtBQUNGIn0=
|
package/package.json
CHANGED
@@ -1,6 +1,6 @@
|
|
1
1
|
{
|
2
2
|
"name": "@payloadcms/db-postgres",
|
3
|
-
"version": "0.
|
3
|
+
"version": "0.2.0",
|
4
4
|
"description": "The officially supported Postgres database adapter for Payload",
|
5
5
|
"repository": "https://github.com/payloadcms/payload",
|
6
6
|
"license": "MIT",
|
@@ -19,13 +19,14 @@
|
|
19
19
|
"drizzle-orm": "0.28.5",
|
20
20
|
"pg": "8.11.3",
|
21
21
|
"prompts": "2.4.2",
|
22
|
-
"to-snake-case": "1.0.0"
|
22
|
+
"to-snake-case": "1.0.0",
|
23
|
+
"uuid": "9.0.0"
|
23
24
|
},
|
24
25
|
"devDependencies": {
|
25
26
|
"@types/pg": "8.10.2",
|
26
27
|
"@types/to-snake-case": "1.0.0",
|
27
28
|
"@payloadcms/eslint-config": "1.0.0",
|
28
|
-
"payload": "2.
|
29
|
+
"payload": "2.3.0"
|
29
30
|
},
|
30
31
|
"peerDependencies": {
|
31
32
|
"payload": "^2.0.0"
|