@payloadcms/db-postgres 0.1.0-beta.0

Sign up to get free protection for your applications and to get access to all the features.
Files changed (74) hide show
  1. package/dist/connect.js +82 -0
  2. package/dist/create.js +32 -0
  3. package/dist/createGlobal.js +32 -0
  4. package/dist/createGlobalVersion.js +48 -0
  5. package/dist/createMigration.js +85 -0
  6. package/dist/createVersion.js +54 -0
  7. package/dist/deleteMany.js +44 -0
  8. package/dist/deleteOne.js +47 -0
  9. package/dist/deleteVersions.js +46 -0
  10. package/dist/destroy.js +16 -0
  11. package/dist/find/buildFindManyArgs.js +61 -0
  12. package/dist/find/chainMethods.js +21 -0
  13. package/dist/find/findMany.js +197 -0
  14. package/dist/find/traverseFields.js +118 -0
  15. package/dist/find.js +35 -0
  16. package/dist/findGlobal.js +38 -0
  17. package/dist/findGlobalVersions.js +39 -0
  18. package/dist/findOne.js +49 -0
  19. package/dist/findVersions.js +39 -0
  20. package/dist/index.js +95 -0
  21. package/dist/init.js +74 -0
  22. package/dist/migrate.js +81 -0
  23. package/dist/migrateStatus.js +54 -0
  24. package/dist/mock.js +13 -0
  25. package/dist/queries/buildAndOrConditions.js +39 -0
  26. package/dist/queries/buildQuery.js +80 -0
  27. package/dist/queries/createJSONQuery/convertPathToJSONTraversal.js +24 -0
  28. package/dist/queries/createJSONQuery/formatJSONPathSegment.js +15 -0
  29. package/dist/queries/createJSONQuery/index.js +64 -0
  30. package/dist/queries/getTableColumnFromPath.js +333 -0
  31. package/dist/queries/operatorMap.js +34 -0
  32. package/dist/queries/parseParams.js +146 -0
  33. package/dist/queries/sanitizeQueryValue.js +79 -0
  34. package/dist/queryDrafts.js +56 -0
  35. package/dist/reference.js +76 -0
  36. package/dist/schema/build.js +245 -0
  37. package/dist/schema/createIndex.js +19 -0
  38. package/dist/schema/parentIDColumnMap.js +18 -0
  39. package/dist/schema/traverseFields.js +430 -0
  40. package/dist/schema/validateExistingBlockIsIdentical.js +34 -0
  41. package/dist/transactions/beginTransaction.js +51 -0
  42. package/dist/transactions/commitTransaction.js +24 -0
  43. package/dist/transactions/rollbackTransaction.js +20 -0
  44. package/dist/transform/read/hasManyNumber.js +20 -0
  45. package/dist/transform/read/index.js +42 -0
  46. package/dist/transform/read/relationship.js +74 -0
  47. package/dist/transform/read/traverseFields.js +325 -0
  48. package/dist/transform/write/array.js +55 -0
  49. package/dist/transform/write/blocks.js +56 -0
  50. package/dist/transform/write/index.js +46 -0
  51. package/dist/transform/write/numbers.js +21 -0
  52. package/dist/transform/write/relationships.js +33 -0
  53. package/dist/transform/write/selects.js +29 -0
  54. package/dist/transform/write/traverseFields.js +379 -0
  55. package/dist/transform/write/types.js +6 -0
  56. package/dist/types.js +6 -0
  57. package/dist/update.js +48 -0
  58. package/dist/updateGlobal.js +39 -0
  59. package/dist/updateGlobalVersion.js +50 -0
  60. package/dist/updateVersion.js +50 -0
  61. package/dist/upsertRow/deleteExistingArrayRows.js +20 -0
  62. package/dist/upsertRow/deleteExistingRowsByPath.js +43 -0
  63. package/dist/upsertRow/index.js +243 -0
  64. package/dist/upsertRow/insertArrays.js +64 -0
  65. package/dist/upsertRow/types.js +6 -0
  66. package/dist/utilities/appendPrefixToKeys.js +16 -0
  67. package/dist/utilities/createBlocksMap.js +39 -0
  68. package/dist/utilities/createMigrationTable.js +23 -0
  69. package/dist/utilities/createRelationshipMap.js +29 -0
  70. package/dist/utilities/hasLocalesTable.js +21 -0
  71. package/dist/utilities/isArrayOfRows.js +15 -0
  72. package/dist/utilities/migrationTableExists.js +19 -0
  73. package/dist/webpack.js +30 -0
  74. package/package.json +47 -0
@@ -0,0 +1,79 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", {
3
+ value: true
4
+ });
5
+ Object.defineProperty(exports, "sanitizeQueryValue", {
6
+ enumerable: true,
7
+ get: function() {
8
+ return sanitizeQueryValue;
9
+ }
10
+ });
11
+ const _errors = require("payload/errors");
12
+ const _types = require("payload/types");
13
+ const _utilities = require("payload/utilities");
14
+ const sanitizeQueryValue = ({ field, operator: operatorArg, val })=>{
15
+ let operator = operatorArg;
16
+ let formattedValue = val;
17
+ if (!(0, _types.fieldAffectsData)(field)) return {
18
+ operator,
19
+ value: formattedValue
20
+ };
21
+ // Cast incoming values as proper searchable types
22
+ if (field.type === 'checkbox' && typeof val === 'string') {
23
+ if (val.toLowerCase() === 'true') formattedValue = true;
24
+ if (val.toLowerCase() === 'false') formattedValue = false;
25
+ }
26
+ if ([
27
+ 'all',
28
+ 'in',
29
+ 'not_in'
30
+ ].includes(operator) && typeof formattedValue === 'string') {
31
+ formattedValue = (0, _utilities.createArrayFromCommaDelineated)(formattedValue);
32
+ if (field.type === 'number') {
33
+ formattedValue = formattedValue.map((arrayVal)=>parseFloat(arrayVal));
34
+ }
35
+ }
36
+ if (field.type === 'number' && typeof formattedValue === 'string') {
37
+ formattedValue = Number(val);
38
+ }
39
+ if (field.type === 'date') {
40
+ if (typeof val === 'string') {
41
+ formattedValue = new Date(val);
42
+ if (Number.isNaN(Date.parse(formattedValue))) {
43
+ return {
44
+ operator,
45
+ value: undefined
46
+ };
47
+ }
48
+ }
49
+ if (typeof val === 'number') {
50
+ formattedValue = new Date(val);
51
+ }
52
+ }
53
+ if ([
54
+ 'relationship',
55
+ 'upload'
56
+ ].includes(field.type)) {
57
+ if (val === 'null') {
58
+ formattedValue = null;
59
+ }
60
+ }
61
+ if (operator === 'near' || operator === 'within' || operator === 'intersects') {
62
+ throw new _errors.APIError(`Querying with '${operator}' is not supported with the postgres database adapter.`);
63
+ }
64
+ if (operator === 'contains') {
65
+ formattedValue = `%${formattedValue}%`;
66
+ }
67
+ if (operator === 'exists') {
68
+ formattedValue = formattedValue === 'true' || formattedValue === true;
69
+ if (formattedValue === false) {
70
+ operator = 'isNull';
71
+ }
72
+ }
73
+ return {
74
+ operator,
75
+ value: formattedValue
76
+ };
77
+ };
78
+
79
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9xdWVyaWVzL3Nhbml0aXplUXVlcnlWYWx1ZS50cyJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBBUElFcnJvciB9IGZyb20gJ3BheWxvYWQvZXJyb3JzJ1xuaW1wb3J0IHsgdHlwZSBGaWVsZCwgdHlwZSBUYWJBc0ZpZWxkLCBmaWVsZEFmZmVjdHNEYXRhIH0gZnJvbSAncGF5bG9hZC90eXBlcydcbmltcG9ydCB7IGNyZWF0ZUFycmF5RnJvbUNvbW1hRGVsaW5lYXRlZCB9IGZyb20gJ3BheWxvYWQvdXRpbGl0aWVzJ1xuXG50eXBlIFNhbml0aXplUXVlcnlWYWx1ZUFyZ3MgPSB7XG4gIGZpZWxkOiBGaWVsZCB8IFRhYkFzRmllbGRcbiAgb3BlcmF0b3I6IHN0cmluZ1xuICB2YWw6IGFueVxufVxuXG5leHBvcnQgY29uc3Qgc2FuaXRpemVRdWVyeVZhbHVlID0gKHtcbiAgZmllbGQsXG4gIG9wZXJhdG9yOiBvcGVyYXRvckFyZyxcbiAgdmFsLFxufTogU2FuaXRpemVRdWVyeVZhbHVlQXJncyk6IHsgb3BlcmF0b3I6IHN0cmluZzsgdmFsdWU6IHVua25vd24gfSA9PiB7XG4gIGxldCBvcGVyYXRvciA9IG9wZXJhdG9yQXJnXG4gIGxldCBmb3JtYXR0ZWRWYWx1ZSA9IHZhbFxuXG4gIGlmICghZmllbGRBZmZlY3RzRGF0YShmaWVsZCkpIHJldHVybiB7IG9wZXJhdG9yLCB2YWx1ZTogZm9ybWF0dGVkVmFsdWUgfVxuXG4gIC8vIENhc3QgaW5jb21pbmcgdmFsdWVzIGFzIHByb3BlciBzZWFyY2hhYmxlIHR5cGVzXG4gIGlmIChmaWVsZC50eXBlID09PSAnY2hlY2tib3gnICYmIHR5cGVvZiB2YWwgPT09ICdzdHJpbmcnKSB7XG4gICAgaWYgKHZhbC50b0xvd2VyQ2FzZSgpID09PSAndHJ1ZScpIGZvcm1hdHRlZFZhbHVlID0gdHJ1ZVxuICAgIGlmICh2YWwudG9Mb3dlckNhc2UoKSA9PT0gJ2ZhbHNlJykgZm9ybWF0dGVkVmFsdWUgPSBmYWxzZVxuICB9XG5cbiAgaWYgKFsnYWxsJywgJ2luJywgJ25vdF9pbiddLmluY2x1ZGVzKG9wZXJhdG9yKSAmJiB0eXBlb2YgZm9ybWF0dGVkVmFsdWUgPT09ICdzdHJpbmcnKSB7XG4gICAgZm9ybWF0dGVkVmFsdWUgPSBjcmVhdGVBcnJheUZyb21Db21tYURlbGluZWF0ZWQoZm9ybWF0dGVkVmFsdWUpXG5cbiAgICBpZiAoZmllbGQudHlwZSA9PT0gJ251bWJlcicpIHtcbiAgICAgIGZvcm1hdHRlZFZhbHVlID0gZm9ybWF0dGVkVmFsdWUubWFwKChhcnJheVZhbCkgPT4gcGFyc2VGbG9hdChhcnJheVZhbCkpXG4gICAgfVxuICB9XG5cbiAgaWYgKGZpZWxkLnR5cGUgPT09ICdudW1iZXInICYmIHR5cGVvZiBmb3JtYXR0ZWRWYWx1ZSA9PT0gJ3N0cmluZycpIHtcbiAgICBmb3JtYXR0ZWRWYWx1ZSA9IE51bWJlcih2YWwpXG4gIH1cblxuICBpZiAoZmllbGQudHlwZSA9PT0gJ2RhdGUnKSB7XG4gICAgaWYgKHR5cGVvZiB2YWwgPT09ICdzdHJpbmcnKSB7XG4gICAgICBmb3JtYXR0ZWRWYWx1ZSA9IG5ldyBEYXRlKHZhbClcbiAgICAgIGlmIChOdW1iZXIuaXNOYU4oRGF0ZS5wYXJzZShmb3JtYXR0ZWRWYWx1ZSkpKSB7XG4gICAgICAgIHJldHVybiB7IG9wZXJhdG9yLCB2YWx1ZTogdW5kZWZpbmVkIH1cbiAgICAgIH1cbiAgICB9XG5cbiAgICBpZiAodHlwZW9mIHZhbCA9PT0gJ251bWJlcicpIHtcbiAgICAgIGZvcm1hdHRlZFZhbHVlID0gbmV3IERhdGUodmFsKVxuICAgIH1cbiAgfVxuXG4gIGlmIChbJ3JlbGF0aW9uc2hpcCcsICd1cGxvYWQnXS5pbmNsdWRlcyhmaWVsZC50eXBlKSkge1xuICAgIGlmICh2YWwgPT09ICdudWxsJykge1xuICAgICAgZm9ybWF0dGVkVmFsdWUgPSBudWxsXG4gICAgfVxuICB9XG5cbiAgaWYgKG9wZXJhdG9yID09PSAnbmVhcicgfHwgb3BlcmF0b3IgPT09ICd3aXRoaW4nIHx8IG9wZXJhdG9yID09PSAnaW50ZXJzZWN0cycpIHtcbiAgICB0aHJvdyBuZXcgQVBJRXJyb3IoXG4gICAgICBgUXVlcnlpbmcgd2l0aCAnJHtvcGVyYXRvcn0nIGlzIG5vdCBzdXBwb3J0ZWQgd2l0aCB0aGUgcG9zdGdyZXMgZGF0YWJhc2UgYWRhcHRlci5gLFxuICAgIClcbiAgfVxuXG4gIGlmIChvcGVyYXRvciA9PT0gJ2NvbnRhaW5zJykge1xuICAgIGZvcm1hdHRlZFZhbHVlID0gYCUke2Zvcm1hdHRlZFZhbHVlfSVgXG4gIH1cblxuICBpZiAob3BlcmF0b3IgPT09ICdleGlzdHMnKSB7XG4gICAgZm9ybWF0dGVkVmFsdWUgPSBmb3JtYXR0ZWRWYWx1ZSA9PT0gJ3RydWUnIHx8IGZvcm1hdHRlZFZhbHVlID09PSB0cnVlXG4gICAgaWYgKGZvcm1hdHRlZFZhbHVlID09PSBmYWxzZSkge1xuICAgICAgb3BlcmF0b3IgPSAnaXNOdWxsJ1xuICAgIH1cbiAgfVxuXG4gIHJldHVybiB7IG9wZXJhdG9yLCB2YWx1ZTogZm9ybWF0dGVkVmFsdWUgfVxufVxuIl0sIm5hbWVzIjpbInNhbml0aXplUXVlcnlWYWx1ZSIsImZpZWxkIiwib3BlcmF0b3IiLCJvcGVyYXRvckFyZyIsInZhbCIsImZvcm1hdHRlZFZhbHVlIiwiZmllbGRBZmZlY3RzRGF0YSIsInZhbHVlIiwidHlwZSIsInRvTG93ZXJDYXNlIiwiaW5jbHVkZXMiLCJjcmVhdGVBcnJheUZyb21Db21tYURlbGluZWF0ZWQiLCJtYXAiLCJhcnJheVZhbCIsInBhcnNlRmxvYXQiLCJOdW1iZXIiLCJEYXRlIiwiaXNOYU4iLCJwYXJzZSIsInVuZGVmaW5lZCIsIkFQSUVycm9yIl0sIm1hcHBpbmdzIjoiOzs7OytCQVVhQTs7O2VBQUFBOzs7d0JBVlk7dUJBQ3FDOzJCQUNmO0FBUXhDLE1BQU1BLHFCQUFxQixDQUFDLEVBQ2pDQyxLQUFLLEVBQ0xDLFVBQVVDLFdBQVcsRUFDckJDLEdBQUcsRUFDb0I7SUFDdkIsSUFBSUYsV0FBV0M7SUFDZixJQUFJRSxpQkFBaUJEO0lBRXJCLElBQUksQ0FBQ0UsSUFBQUEsdUJBQWdCLEVBQUNMLFFBQVEsT0FBTztRQUFFQztRQUFVSyxPQUFPRjtJQUFlO0lBRXZFLGtEQUFrRDtJQUNsRCxJQUFJSixNQUFNTyxJQUFJLEtBQUssY0FBYyxPQUFPSixRQUFRLFVBQVU7UUFDeEQsSUFBSUEsSUFBSUssV0FBVyxPQUFPLFFBQVFKLGlCQUFpQjtRQUNuRCxJQUFJRCxJQUFJSyxXQUFXLE9BQU8sU0FBU0osaUJBQWlCO0lBQ3REO0lBRUEsSUFBSTtRQUFDO1FBQU87UUFBTTtLQUFTLENBQUNLLFFBQVEsQ0FBQ1IsYUFBYSxPQUFPRyxtQkFBbUIsVUFBVTtRQUNwRkEsaUJBQWlCTSxJQUFBQSx5Q0FBOEIsRUFBQ047UUFFaEQsSUFBSUosTUFBTU8sSUFBSSxLQUFLLFVBQVU7WUFDM0JILGlCQUFpQkEsZUFBZU8sR0FBRyxDQUFDLENBQUNDLFdBQWFDLFdBQVdEO1FBQy9EO0lBQ0Y7SUFFQSxJQUFJWixNQUFNTyxJQUFJLEtBQUssWUFBWSxPQUFPSCxtQkFBbUIsVUFBVTtRQUNqRUEsaUJBQWlCVSxPQUFPWDtJQUMxQjtJQUVBLElBQUlILE1BQU1PLElBQUksS0FBSyxRQUFRO1FBQ3pCLElBQUksT0FBT0osUUFBUSxVQUFVO1lBQzNCQyxpQkFBaUIsSUFBSVcsS0FBS1o7WUFDMUIsSUFBSVcsT0FBT0UsS0FBSyxDQUFDRCxLQUFLRSxLQUFLLENBQUNiLGtCQUFrQjtnQkFDNUMsT0FBTztvQkFBRUg7b0JBQVVLLE9BQU9ZO2dCQUFVO1lBQ3RDO1FBQ0Y7UUFFQSxJQUFJLE9BQU9mLFFBQVEsVUFBVTtZQUMzQkMsaUJBQWlCLElBQUlXLEtBQUtaO1FBQzVCO0lBQ0Y7SUFFQSxJQUFJO1FBQUM7UUFBZ0I7S0FBUyxDQUFDTSxRQUFRLENBQUNULE1BQU1PLElBQUksR0FBRztRQUNuRCxJQUFJSixRQUFRLFFBQVE7WUFDbEJDLGlCQUFpQjtRQUNuQjtJQUNGO0lBRUEsSUFBSUgsYUFBYSxVQUFVQSxhQUFhLFlBQVlBLGFBQWEsY0FBYztRQUM3RSxNQUFNLElBQUlrQixnQkFBUSxDQUNoQixDQUFDLGVBQWUsRUFBRWxCLFNBQVMsc0RBQXNELENBQUM7SUFFdEY7SUFFQSxJQUFJQSxhQUFhLFlBQVk7UUFDM0JHLGlCQUFpQixDQUFDLENBQUMsRUFBRUEsZUFBZSxDQUFDLENBQUM7SUFDeEM7SUFFQSxJQUFJSCxhQUFhLFVBQVU7UUFDekJHLGlCQUFpQkEsbUJBQW1CLFVBQVVBLG1CQUFtQjtRQUNqRSxJQUFJQSxtQkFBbUIsT0FBTztZQUM1QkgsV0FBVztRQUNiO0lBQ0Y7SUFFQSxPQUFPO1FBQUVBO1FBQVVLLE9BQU9GO0lBQWU7QUFDM0MifQ==
@@ -0,0 +1,56 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", {
3
+ value: true
4
+ });
5
+ Object.defineProperty(exports, "queryDrafts", {
6
+ enumerable: true,
7
+ get: function() {
8
+ return queryDrafts;
9
+ }
10
+ });
11
+ const _database = require("payload/database");
12
+ const _versions = require("payload/versions");
13
+ const _tosnakecase = /*#__PURE__*/ _interop_require_default(require("to-snake-case"));
14
+ const _findMany = require("./find/findMany");
15
+ function _interop_require_default(obj) {
16
+ return obj && obj.__esModule ? obj : {
17
+ default: obj
18
+ };
19
+ }
20
+ const queryDrafts = async function queryDrafts({ collection, limit, locale, page = 1, pagination, req = {}, sort, where }) {
21
+ const collectionConfig = this.payload.collections[collection].config;
22
+ const tableName = `_${(0, _tosnakecase.default)(collection)}_v`;
23
+ const fields = (0, _versions.buildVersionCollectionFields)(collectionConfig);
24
+ const combinedWhere = (0, _database.combineQueries)({
25
+ latest: {
26
+ equals: true
27
+ }
28
+ }, where);
29
+ const result = await (0, _findMany.findMany)({
30
+ adapter: this,
31
+ fields,
32
+ limit,
33
+ locale,
34
+ page,
35
+ pagination,
36
+ req,
37
+ sort,
38
+ tableName,
39
+ where: combinedWhere
40
+ });
41
+ return {
42
+ ...result,
43
+ docs: result.docs.map((doc)=>{
44
+ // eslint-disable-next-line no-param-reassign
45
+ doc = {
46
+ id: doc.parent,
47
+ ...doc.version,
48
+ createdAt: doc.createdAt,
49
+ updatedAt: doc.updatedAt
50
+ };
51
+ return doc;
52
+ })
53
+ };
54
+ };
55
+
56
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uL3NyYy9xdWVyeURyYWZ0cy50cyJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgdHlwZSB7IFBheWxvYWRSZXF1ZXN0LCBTYW5pdGl6ZWRDb2xsZWN0aW9uQ29uZmlnIH0gZnJvbSAncGF5bG9hZC90eXBlcydcblxuaW1wb3J0IHsgdHlwZSBRdWVyeURyYWZ0cywgY29tYmluZVF1ZXJpZXMgfSBmcm9tICdwYXlsb2FkL2RhdGFiYXNlJ1xuaW1wb3J0IHsgYnVpbGRWZXJzaW9uQ29sbGVjdGlvbkZpZWxkcyB9IGZyb20gJ3BheWxvYWQvdmVyc2lvbnMnXG5pbXBvcnQgdG9TbmFrZUNhc2UgZnJvbSAndG8tc25ha2UtY2FzZSdcblxuaW1wb3J0IHsgZmluZE1hbnkgfSBmcm9tICcuL2ZpbmQvZmluZE1hbnknXG5cbmV4cG9ydCBjb25zdCBxdWVyeURyYWZ0czogUXVlcnlEcmFmdHMgPSBhc3luYyBmdW5jdGlvbiBxdWVyeURyYWZ0cyh7XG4gIGNvbGxlY3Rpb24sXG4gIGxpbWl0LFxuICBsb2NhbGUsXG4gIHBhZ2UgPSAxLFxuICBwYWdpbmF0aW9uLFxuICByZXEgPSB7fSBhcyBQYXlsb2FkUmVxdWVzdCxcbiAgc29ydCxcbiAgd2hlcmUsXG59KSB7XG4gIGNvbnN0IGNvbGxlY3Rpb25Db25maWc6IFNhbml0aXplZENvbGxlY3Rpb25Db25maWcgPSB0aGlzLnBheWxvYWQuY29sbGVjdGlvbnNbY29sbGVjdGlvbl0uY29uZmlnXG4gIGNvbnN0IHRhYmxlTmFtZSA9IGBfJHt0b1NuYWtlQ2FzZShjb2xsZWN0aW9uKX1fdmBcbiAgY29uc3QgZmllbGRzID0gYnVpbGRWZXJzaW9uQ29sbGVjdGlvbkZpZWxkcyhjb2xsZWN0aW9uQ29uZmlnKVxuXG4gIGNvbnN0IGNvbWJpbmVkV2hlcmUgPSBjb21iaW5lUXVlcmllcyh7IGxhdGVzdDogeyBlcXVhbHM6IHRydWUgfSB9LCB3aGVyZSlcblxuICBjb25zdCByZXN1bHQgPSBhd2FpdCBmaW5kTWFueSh7XG4gICAgYWRhcHRlcjogdGhpcyxcbiAgICBmaWVsZHMsXG4gICAgbGltaXQsXG4gICAgbG9jYWxlLFxuICAgIHBhZ2UsXG4gICAgcGFnaW5hdGlvbixcbiAgICByZXEsXG4gICAgc29ydCxcbiAgICB0YWJsZU5hbWUsXG4gICAgd2hlcmU6IGNvbWJpbmVkV2hlcmUsXG4gIH0pXG5cbiAgcmV0dXJuIHtcbiAgICAuLi5yZXN1bHQsXG4gICAgZG9jczogcmVzdWx0LmRvY3MubWFwKChkb2MpID0+IHtcbiAgICAgIC8vIGVzbGludC1kaXNhYmxlLW5leHQtbGluZSBuby1wYXJhbS1yZWFzc2lnblxuICAgICAgZG9jID0ge1xuICAgICAgICBpZDogZG9jLnBhcmVudCxcbiAgICAgICAgLi4uZG9jLnZlcnNpb24sXG4gICAgICAgIGNyZWF0ZWRBdDogZG9jLmNyZWF0ZWRBdCxcbiAgICAgICAgdXBkYXRlZEF0OiBkb2MudXBkYXRlZEF0LFxuICAgICAgfVxuXG4gICAgICByZXR1cm4gZG9jXG4gICAgfSksXG4gIH1cbn1cbiJdLCJuYW1lcyI6WyJxdWVyeURyYWZ0cyIsImNvbGxlY3Rpb24iLCJsaW1pdCIsImxvY2FsZSIsInBhZ2UiLCJwYWdpbmF0aW9uIiwicmVxIiwic29ydCIsIndoZXJlIiwiY29sbGVjdGlvbkNvbmZpZyIsInBheWxvYWQiLCJjb2xsZWN0aW9ucyIsImNvbmZpZyIsInRhYmxlTmFtZSIsInRvU25ha2VDYXNlIiwiZmllbGRzIiwiYnVpbGRWZXJzaW9uQ29sbGVjdGlvbkZpZWxkcyIsImNvbWJpbmVkV2hlcmUiLCJjb21iaW5lUXVlcmllcyIsImxhdGVzdCIsImVxdWFscyIsInJlc3VsdCIsImZpbmRNYW55IiwiYWRhcHRlciIsImRvY3MiLCJtYXAiLCJkb2MiLCJpZCIsInBhcmVudCIsInZlcnNpb24iLCJjcmVhdGVkQXQiLCJ1cGRhdGVkQXQiXSwibWFwcGluZ3MiOiI7Ozs7K0JBUWFBOzs7ZUFBQUE7OzswQkFOb0M7MEJBQ0o7b0VBQ3JCOzBCQUVDOzs7Ozs7QUFFbEIsTUFBTUEsY0FBMkIsZUFBZUEsWUFBWSxFQUNqRUMsVUFBVSxFQUNWQyxLQUFLLEVBQ0xDLE1BQU0sRUFDTkMsT0FBTyxDQUFDLEVBQ1JDLFVBQVUsRUFDVkMsTUFBTSxDQUFDLENBQW1CLEVBQzFCQyxJQUFJLEVBQ0pDLEtBQUssRUFDTjtJQUNDLE1BQU1DLG1CQUE4QyxJQUFJLENBQUNDLE9BQU8sQ0FBQ0MsV0FBVyxDQUFDVixXQUFXLENBQUNXLE1BQU07SUFDL0YsTUFBTUMsWUFBWSxDQUFDLENBQUMsRUFBRUMsSUFBQUEsb0JBQVcsRUFBQ2IsWUFBWSxFQUFFLENBQUM7SUFDakQsTUFBTWMsU0FBU0MsSUFBQUEsc0NBQTRCLEVBQUNQO0lBRTVDLE1BQU1RLGdCQUFnQkMsSUFBQUEsd0JBQWMsRUFBQztRQUFFQyxRQUFRO1lBQUVDLFFBQVE7UUFBSztJQUFFLEdBQUdaO0lBRW5FLE1BQU1hLFNBQVMsTUFBTUMsSUFBQUEsa0JBQVEsRUFBQztRQUM1QkMsU0FBUyxJQUFJO1FBQ2JSO1FBQ0FiO1FBQ0FDO1FBQ0FDO1FBQ0FDO1FBQ0FDO1FBQ0FDO1FBQ0FNO1FBQ0FMLE9BQU9TO0lBQ1Q7SUFFQSxPQUFPO1FBQ0wsR0FBR0ksTUFBTTtRQUNURyxNQUFNSCxPQUFPRyxJQUFJLENBQUNDLEdBQUcsQ0FBQyxDQUFDQztZQUNyQiw2Q0FBNkM7WUFDN0NBLE1BQU07Z0JBQ0pDLElBQUlELElBQUlFLE1BQU07Z0JBQ2QsR0FBR0YsSUFBSUcsT0FBTztnQkFDZEMsV0FBV0osSUFBSUksU0FBUztnQkFDeEJDLFdBQVdMLElBQUlLLFNBQVM7WUFDMUI7WUFFQSxPQUFPTDtRQUNUO0lBQ0Y7QUFDRiJ9
@@ -0,0 +1,76 @@
1
+ // type GenerateMigration = (before: DrizzleSnapshotJSON, after: DrizzleSnapshotJSON) => string[]
2
+ // type GenerateDrizzleJSON = (schema: DrizzleSchemaExports) => DrizzleSnapshotJSON
3
+ // type PushDiff = (schema: DrizzleSchemaExports) => Promise<{ warnings: string[], apply: () => Promise<void> }>
4
+ // drizzle-kit@utils
5
+ "use strict";
6
+ Object.defineProperty(exports, "__esModule", {
7
+ value: true
8
+ });
9
+ const _utils = require("drizzle-kit/utils");
10
+ const _nodepostgres = require("drizzle-orm/node-postgres");
11
+ const _pg = require("pg");
12
+ function _getRequireWildcardCache(nodeInterop) {
13
+ if (typeof WeakMap !== "function") return null;
14
+ var cacheBabelInterop = new WeakMap();
15
+ var cacheNodeInterop = new WeakMap();
16
+ return (_getRequireWildcardCache = function(nodeInterop) {
17
+ return nodeInterop ? cacheNodeInterop : cacheBabelInterop;
18
+ })(nodeInterop);
19
+ }
20
+ function _interop_require_wildcard(obj, nodeInterop) {
21
+ if (!nodeInterop && obj && obj.__esModule) {
22
+ return obj;
23
+ }
24
+ if (obj === null || typeof obj !== "object" && typeof obj !== "function") {
25
+ return {
26
+ default: obj
27
+ };
28
+ }
29
+ var cache = _getRequireWildcardCache(nodeInterop);
30
+ if (cache && cache.has(obj)) {
31
+ return cache.get(obj);
32
+ }
33
+ var newObj = {};
34
+ var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor;
35
+ for(var key in obj){
36
+ if (key !== "default" && Object.prototype.hasOwnProperty.call(obj, key)) {
37
+ var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null;
38
+ if (desc && (desc.get || desc.set)) {
39
+ Object.defineProperty(newObj, key, desc);
40
+ } else {
41
+ newObj[key] = obj[key];
42
+ }
43
+ }
44
+ }
45
+ newObj.default = obj;
46
+ if (cache) {
47
+ cache.set(obj, newObj);
48
+ }
49
+ return newObj;
50
+ }
51
+ async function generateUsage() {
52
+ // @ts-expect-error Just TypeScript being broken // TODO: Open TypeScript issue
53
+ const schema = await Promise.resolve().then(()=>/*#__PURE__*/ _interop_require_wildcard(require("./data/users")));
54
+ // @ts-expect-error Just TypeScript being broken // TODO: Open TypeScript issue
55
+ const schemaAfter = await Promise.resolve().then(()=>/*#__PURE__*/ _interop_require_wildcard(require("./data/users-after")));
56
+ const drizzleJsonBefore = (0, _utils.generateDrizzleJson)(schema);
57
+ const drizzleJsonAfter = (0, _utils.generateDrizzleJson)(schemaAfter);
58
+ const sqlStatements = await (0, _utils.generateMigration)(drizzleJsonBefore, drizzleJsonAfter);
59
+ console.log(sqlStatements);
60
+ }
61
+ async function pushUsage() {
62
+ // @ts-expect-error Just TypeScript being broken // TODO: Open TypeScript issue
63
+ const schemaAfter = await Promise.resolve().then(()=>/*#__PURE__*/ _interop_require_wildcard(require("./data/users-after")));
64
+ const db = (0, _nodepostgres.drizzle)(new _pg.Pool({
65
+ connectionString: ''
66
+ }));
67
+ const response = await (0, _utils.pushSchema)(schemaAfter, db);
68
+ console.log('\n');
69
+ console.log('hasDataLoss: ', response.hasDataLoss);
70
+ console.log('warnings: ', response.warnings);
71
+ console.log('statements: ', response.statementsToExecute);
72
+ await response.apply();
73
+ process.exit(0);
74
+ }
75
+
76
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uL3NyYy9yZWZlcmVuY2UudHMiXSwic291cmNlc0NvbnRlbnQiOlsiLy8gdHlwZSBHZW5lcmF0ZU1pZ3JhdGlvbiA9IChiZWZvcmU6IERyaXp6bGVTbmFwc2hvdEpTT04sIGFmdGVyOiBEcml6emxlU25hcHNob3RKU09OKSA9PiBzdHJpbmdbXVxuXG4vLyB0eXBlIEdlbmVyYXRlRHJpenpsZUpTT04gPSAoc2NoZW1hOiBEcml6emxlU2NoZW1hRXhwb3J0cykgPT4gRHJpenpsZVNuYXBzaG90SlNPTlxuXG4vLyB0eXBlIFB1c2hEaWZmID0gKHNjaGVtYTogRHJpenpsZVNjaGVtYUV4cG9ydHMpID0+IFByb21pc2U8eyB3YXJuaW5nczogc3RyaW5nW10sIGFwcGx5OiAoKSA9PiBQcm9taXNlPHZvaWQ+IH0+XG5cbi8vIGRyaXp6bGUta2l0QHV0aWxzXG5cbmltcG9ydCB7IGdlbmVyYXRlRHJpenpsZUpzb24sIGdlbmVyYXRlTWlncmF0aW9uLCBwdXNoU2NoZW1hIH0gZnJvbSAnZHJpenpsZS1raXQvdXRpbHMnXG5pbXBvcnQgeyBkcml6emxlIH0gZnJvbSAnZHJpenpsZS1vcm0vbm9kZS1wb3N0Z3JlcydcbmltcG9ydCB7IFBvb2wgfSBmcm9tICdwZydcblxuYXN5bmMgZnVuY3Rpb24gZ2VuZXJhdGVVc2FnZSgpIHtcbiAgLy8gQHRzLWV4cGVjdC1lcnJvciBKdXN0IFR5cGVTY3JpcHQgYmVpbmcgYnJva2VuIC8vIFRPRE86IE9wZW4gVHlwZVNjcmlwdCBpc3N1ZVxuICBjb25zdCBzY2hlbWEgPSBhd2FpdCBpbXBvcnQoJy4vZGF0YS91c2VycycpXG4gIC8vIEB0cy1leHBlY3QtZXJyb3IgSnVzdCBUeXBlU2NyaXB0IGJlaW5nIGJyb2tlbiAvLyBUT0RPOiBPcGVuIFR5cGVTY3JpcHQgaXNzdWVcbiAgY29uc3Qgc2NoZW1hQWZ0ZXIgPSBhd2FpdCBpbXBvcnQoJy4vZGF0YS91c2Vycy1hZnRlcicpXG5cbiAgY29uc3QgZHJpenpsZUpzb25CZWZvcmUgPSBnZW5lcmF0ZURyaXp6bGVKc29uKHNjaGVtYSlcbiAgY29uc3QgZHJpenpsZUpzb25BZnRlciA9IGdlbmVyYXRlRHJpenpsZUpzb24oc2NoZW1hQWZ0ZXIpXG5cbiAgY29uc3Qgc3FsU3RhdGVtZW50cyA9IGF3YWl0IGdlbmVyYXRlTWlncmF0aW9uKGRyaXp6bGVKc29uQmVmb3JlLCBkcml6emxlSnNvbkFmdGVyKVxuXG4gIGNvbnNvbGUubG9nKHNxbFN0YXRlbWVudHMpXG59XG5cbmFzeW5jIGZ1bmN0aW9uIHB1c2hVc2FnZSgpIHtcbiAgLy8gQHRzLWV4cGVjdC1lcnJvciBKdXN0IFR5cGVTY3JpcHQgYmVpbmcgYnJva2VuIC8vIFRPRE86IE9wZW4gVHlwZVNjcmlwdCBpc3N1ZVxuICBjb25zdCBzY2hlbWFBZnRlciA9IGF3YWl0IGltcG9ydCgnLi9kYXRhL3VzZXJzLWFmdGVyJylcblxuICBjb25zdCBkYiA9IGRyaXp6bGUobmV3IFBvb2woeyBjb25uZWN0aW9uU3RyaW5nOiAnJyB9KSlcblxuICBjb25zdCByZXNwb25zZSA9IGF3YWl0IHB1c2hTY2hlbWEoc2NoZW1hQWZ0ZXIsIGRiKVxuXG4gIGNvbnNvbGUubG9nKCdcXG4nKVxuICBjb25zb2xlLmxvZygnaGFzRGF0YUxvc3M6ICcsIHJlc3BvbnNlLmhhc0RhdGFMb3NzKVxuICBjb25zb2xlLmxvZygnd2FybmluZ3M6ICcsIHJlc3BvbnNlLndhcm5pbmdzKVxuICBjb25zb2xlLmxvZygnc3RhdGVtZW50czogJywgcmVzcG9uc2Uuc3RhdGVtZW50c1RvRXhlY3V0ZSlcblxuICBhd2FpdCByZXNwb25zZS5hcHBseSgpXG5cbiAgcHJvY2Vzcy5leGl0KDApXG59XG4iXSwibmFtZXMiOlsiZ2VuZXJhdGVVc2FnZSIsInNjaGVtYSIsInNjaGVtYUFmdGVyIiwiZHJpenpsZUpzb25CZWZvcmUiLCJnZW5lcmF0ZURyaXp6bGVKc29uIiwiZHJpenpsZUpzb25BZnRlciIsInNxbFN0YXRlbWVudHMiLCJnZW5lcmF0ZU1pZ3JhdGlvbiIsImNvbnNvbGUiLCJsb2ciLCJwdXNoVXNhZ2UiLCJkYiIsImRyaXp6bGUiLCJQb29sIiwiY29ubmVjdGlvblN0cmluZyIsInJlc3BvbnNlIiwicHVzaFNjaGVtYSIsImhhc0RhdGFMb3NzIiwid2FybmluZ3MiLCJzdGF0ZW1lbnRzVG9FeGVjdXRlIiwiYXBwbHkiLCJwcm9jZXNzIiwiZXhpdCJdLCJtYXBwaW5ncyI6IkFBQUEsaUdBQWlHO0FBRWpHLG1GQUFtRjtBQUVuRixnSEFBZ0g7QUFFaEgsb0JBQW9COzs7Ozt1QkFFK0M7OEJBQzNDO29CQUNIOzs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7O0FBRXJCLGVBQWVBO0lBQ2IsK0VBQStFO0lBQy9FLE1BQU1DLFNBQVMsTUFBTSxtRUFBQSxRQUFPO0lBQzVCLCtFQUErRTtJQUMvRSxNQUFNQyxjQUFjLE1BQU0sbUVBQUEsUUFBTztJQUVqQyxNQUFNQyxvQkFBb0JDLElBQUFBLDBCQUFtQixFQUFDSDtJQUM5QyxNQUFNSSxtQkFBbUJELElBQUFBLDBCQUFtQixFQUFDRjtJQUU3QyxNQUFNSSxnQkFBZ0IsTUFBTUMsSUFBQUEsd0JBQWlCLEVBQUNKLG1CQUFtQkU7SUFFakVHLFFBQVFDLEdBQUcsQ0FBQ0g7QUFDZDtBQUVBLGVBQWVJO0lBQ2IsK0VBQStFO0lBQy9FLE1BQU1SLGNBQWMsTUFBTSxtRUFBQSxRQUFPO0lBRWpDLE1BQU1TLEtBQUtDLElBQUFBLHFCQUFPLEVBQUMsSUFBSUMsUUFBSSxDQUFDO1FBQUVDLGtCQUFrQjtJQUFHO0lBRW5ELE1BQU1DLFdBQVcsTUFBTUMsSUFBQUEsaUJBQVUsRUFBQ2QsYUFBYVM7SUFFL0NILFFBQVFDLEdBQUcsQ0FBQztJQUNaRCxRQUFRQyxHQUFHLENBQUMsaUJBQWlCTSxTQUFTRSxXQUFXO0lBQ2pEVCxRQUFRQyxHQUFHLENBQUMsY0FBY00sU0FBU0csUUFBUTtJQUMzQ1YsUUFBUUMsR0FBRyxDQUFDLGdCQUFnQk0sU0FBU0ksbUJBQW1CO0lBRXhELE1BQU1KLFNBQVNLLEtBQUs7SUFFcEJDLFFBQVFDLElBQUksQ0FBQztBQUNmIn0=
@@ -0,0 +1,245 @@
1
+ /* eslint-disable no-param-reassign */ "use strict";
2
+ Object.defineProperty(exports, "__esModule", {
3
+ value: true
4
+ });
5
+ Object.defineProperty(exports, "buildTable", {
6
+ enumerable: true,
7
+ get: function() {
8
+ return buildTable;
9
+ }
10
+ });
11
+ const _drizzleorm = require("drizzle-orm");
12
+ const _pgcore = require("drizzle-orm/pg-core");
13
+ const _types = require("payload/types");
14
+ const _tosnakecase = /*#__PURE__*/ _interop_require_default(require("to-snake-case"));
15
+ const _parentIDColumnMap = require("./parentIDColumnMap");
16
+ const _traverseFields = require("./traverseFields");
17
+ function _interop_require_default(obj) {
18
+ return obj && obj.__esModule ? obj : {
19
+ default: obj
20
+ };
21
+ }
22
+ const buildTable = ({ adapter, baseColumns = {}, baseExtraConfig = {}, buildRelationships, disableUnique = false, fields, rootRelationsToBuild, rootTableIDColType, rootTableName, tableName, timestamps })=>{
23
+ const columns = baseColumns;
24
+ const indexes = {};
25
+ let hasLocalizedField = false;
26
+ let hasLocalizedRelationshipField = false;
27
+ let hasManyNumberField = false;
28
+ let hasLocalizedManyNumberField = false;
29
+ const localesColumns = {};
30
+ const localesIndexes = {};
31
+ let localesTable;
32
+ let numbersTable;
33
+ const relationships = new Set();
34
+ let relationshipsTable;
35
+ const relationsToBuild = new Map();
36
+ const idField = fields.find((field)=>(0, _types.fieldAffectsData)(field) && field.name === 'id');
37
+ let idColType = 'integer';
38
+ if (idField) {
39
+ if (idField.type === 'number') {
40
+ idColType = 'numeric';
41
+ columns.id = (0, _pgcore.numeric)('id').primaryKey();
42
+ }
43
+ if (idField.type === 'text') {
44
+ idColType = 'varchar';
45
+ columns.id = (0, _pgcore.varchar)('id').primaryKey();
46
+ }
47
+ } else {
48
+ columns.id = (0, _pgcore.serial)('id').primaryKey();
49
+ }
50
+ ({ hasLocalizedField, hasLocalizedManyNumberField, hasLocalizedRelationshipField, hasManyNumberField } = (0, _traverseFields.traverseFields)({
51
+ adapter,
52
+ buildRelationships,
53
+ columns,
54
+ disableUnique,
55
+ fields,
56
+ indexes,
57
+ localesColumns,
58
+ localesIndexes,
59
+ newTableName: tableName,
60
+ parentTableName: tableName,
61
+ relationsToBuild,
62
+ relationships,
63
+ rootRelationsToBuild: rootRelationsToBuild || relationsToBuild,
64
+ rootTableIDColType: rootTableIDColType || idColType,
65
+ rootTableName: rootTableName || tableName
66
+ }));
67
+ if (timestamps) {
68
+ columns.createdAt = (0, _pgcore.timestamp)('created_at', {
69
+ mode: 'string',
70
+ precision: 3,
71
+ withTimezone: true
72
+ }).defaultNow().notNull();
73
+ columns.updatedAt = (0, _pgcore.timestamp)('updated_at', {
74
+ mode: 'string',
75
+ precision: 3,
76
+ withTimezone: true
77
+ }).defaultNow().notNull();
78
+ }
79
+ const table = (0, _pgcore.pgTable)(tableName, columns, (cols)=>{
80
+ const extraConfig = Object.entries(baseExtraConfig).reduce((config, [key, func])=>{
81
+ config[key] = func(cols);
82
+ return config;
83
+ }, {});
84
+ return Object.entries(indexes).reduce((acc, [colName, func])=>{
85
+ acc[colName] = func(cols);
86
+ return acc;
87
+ }, extraConfig);
88
+ });
89
+ adapter.tables[tableName] = table;
90
+ if (hasLocalizedField) {
91
+ const localeTableName = `${tableName}_locales`;
92
+ localesColumns.id = (0, _pgcore.serial)('id').primaryKey();
93
+ localesColumns._locale = adapter.enums.enum__locales('_locale').notNull();
94
+ localesColumns._parentID = _parentIDColumnMap.parentIDColumnMap[idColType]('_parent_id').references(()=>table.id, {
95
+ onDelete: 'cascade'
96
+ }).notNull();
97
+ localesTable = (0, _pgcore.pgTable)(localeTableName, localesColumns, (cols)=>{
98
+ return Object.entries(localesIndexes).reduce((acc, [colName, func])=>{
99
+ acc[colName] = func(cols);
100
+ return acc;
101
+ }, {
102
+ _localeParent: (0, _pgcore.unique)().on(cols._locale, cols._parentID)
103
+ });
104
+ });
105
+ adapter.tables[localeTableName] = localesTable;
106
+ const localesTableRelations = (0, _drizzleorm.relations)(localesTable, ({ one })=>({
107
+ _parentID: one(table, {
108
+ fields: [
109
+ localesTable._parentID
110
+ ],
111
+ references: [
112
+ table.id
113
+ ]
114
+ })
115
+ }));
116
+ adapter.relations[`relations_${localeTableName}`] = localesTableRelations;
117
+ }
118
+ if (hasManyNumberField) {
119
+ const numbersTableName = `${tableName}_numbers`;
120
+ const columns = {
121
+ id: (0, _pgcore.serial)('id').primaryKey(),
122
+ number: (0, _pgcore.numeric)('number'),
123
+ order: (0, _pgcore.integer)('order').notNull(),
124
+ parent: _parentIDColumnMap.parentIDColumnMap[idColType]('parent_id').references(()=>table.id, {
125
+ onDelete: 'cascade'
126
+ }).notNull(),
127
+ path: (0, _pgcore.varchar)('path').notNull()
128
+ };
129
+ if (hasLocalizedManyNumberField) {
130
+ columns.locale = adapter.enums.enum__locales('locale');
131
+ }
132
+ numbersTable = (0, _pgcore.pgTable)(numbersTableName, columns, (cols)=>{
133
+ const indexes = {
134
+ orderParentIdx: (0, _pgcore.index)('order_parent_idx').on(cols.order, cols.parent)
135
+ };
136
+ if (hasManyNumberField === 'index') {
137
+ indexes.numberIdx = (0, _pgcore.index)('number_idx').on(cols.number);
138
+ }
139
+ if (hasLocalizedManyNumberField) {
140
+ indexes.localeParent = (0, _pgcore.index)('locale_parent').on(cols.locale, cols.parent);
141
+ }
142
+ return indexes;
143
+ });
144
+ adapter.tables[numbersTableName] = numbersTable;
145
+ const numbersTableRelations = (0, _drizzleorm.relations)(numbersTable, ({ one })=>({
146
+ parent: one(table, {
147
+ fields: [
148
+ numbersTable.parent
149
+ ],
150
+ references: [
151
+ table.id
152
+ ]
153
+ })
154
+ }));
155
+ adapter.relations[`relations_${numbersTableName}`] = numbersTableRelations;
156
+ }
157
+ if (buildRelationships) {
158
+ if (relationships.size) {
159
+ const relationshipColumns = {
160
+ id: (0, _pgcore.serial)('id').primaryKey(),
161
+ order: (0, _pgcore.integer)('order'),
162
+ parent: _parentIDColumnMap.parentIDColumnMap[idColType]('parent_id').references(()=>table.id, {
163
+ onDelete: 'cascade'
164
+ }).notNull(),
165
+ path: (0, _pgcore.varchar)('path').notNull()
166
+ };
167
+ if (hasLocalizedRelationshipField) {
168
+ relationshipColumns.locale = adapter.enums.enum__locales('locale');
169
+ }
170
+ relationships.forEach((relationTo)=>{
171
+ const formattedRelationTo = (0, _tosnakecase.default)(relationTo);
172
+ let colType = 'integer';
173
+ const relatedCollectionCustomID = adapter.payload.collections[relationTo].config.fields.find((field)=>(0, _types.fieldAffectsData)(field) && field.name === 'id');
174
+ if (relatedCollectionCustomID?.type === 'number') colType = 'numeric';
175
+ if (relatedCollectionCustomID?.type === 'text') colType = 'varchar';
176
+ relationshipColumns[`${relationTo}ID`] = _parentIDColumnMap.parentIDColumnMap[colType](`${formattedRelationTo}_id`).references(()=>adapter.tables[formattedRelationTo].id, {
177
+ onDelete: 'cascade'
178
+ });
179
+ });
180
+ const relationshipsTableName = `${tableName}_relationships`;
181
+ relationshipsTable = (0, _pgcore.pgTable)(relationshipsTableName, relationshipColumns, (cols)=>{
182
+ const result = {};
183
+ if (hasLocalizedRelationshipField) {
184
+ result.localeIdx = (0, _pgcore.index)('locale_idx').on(cols.locale);
185
+ result.parentPathOrderLocale = (0, _pgcore.unique)().on(cols.parent, cols.path, cols.order, cols.locale);
186
+ } else {
187
+ result.parentPathOrder = (0, _pgcore.unique)().on(cols.parent, cols.path, cols.order);
188
+ }
189
+ return result;
190
+ });
191
+ adapter.tables[relationshipsTableName] = relationshipsTable;
192
+ const relationshipsTableRelations = (0, _drizzleorm.relations)(relationshipsTable, ({ one })=>{
193
+ const result = {
194
+ parent: one(table, {
195
+ fields: [
196
+ relationshipsTable.parent
197
+ ],
198
+ references: [
199
+ table.id
200
+ ],
201
+ relationName: '_relationships'
202
+ })
203
+ };
204
+ relationships.forEach((relationTo)=>{
205
+ const relatedTableName = (0, _tosnakecase.default)(relationTo);
206
+ const idColumnName = `${relationTo}ID`;
207
+ result[idColumnName] = one(adapter.tables[relatedTableName], {
208
+ fields: [
209
+ relationshipsTable[idColumnName]
210
+ ],
211
+ references: [
212
+ adapter.tables[relatedTableName].id
213
+ ]
214
+ });
215
+ });
216
+ return result;
217
+ });
218
+ adapter.relations[`relations_${relationshipsTableName}`] = relationshipsTableRelations;
219
+ }
220
+ }
221
+ const tableRelations = (0, _drizzleorm.relations)(table, ({ many })=>{
222
+ const result = {};
223
+ relationsToBuild.forEach((val, key)=>{
224
+ result[key] = many(adapter.tables[val]);
225
+ });
226
+ if (hasLocalizedField) {
227
+ result._locales = many(localesTable);
228
+ }
229
+ if (hasManyNumberField) {
230
+ result._numbers = many(numbersTable);
231
+ }
232
+ if (relationships.size && relationshipsTable) {
233
+ result._relationships = many(relationshipsTable, {
234
+ relationName: '_relationships'
235
+ });
236
+ }
237
+ return result;
238
+ });
239
+ adapter.relations[`relations_${tableName}`] = tableRelations;
240
+ return {
241
+ relationsToBuild
242
+ };
243
+ };
244
+
245
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../src/schema/build.ts"],"sourcesContent":["/* eslint-disable no-param-reassign */\nimport type { Relation } from 'drizzle-orm'\nimport type { IndexBuilder, PgColumnBuilder, UniqueConstraintBuilder } from 'drizzle-orm/pg-core'\nimport type { Field } from 'payload/types'\n\nimport { relations } from 'drizzle-orm'\nimport {\n  index,\n  integer,\n  numeric,\n  pgTable,\n  serial,\n  timestamp,\n  unique,\n  varchar,\n} from 'drizzle-orm/pg-core'\nimport { fieldAffectsData } from 'payload/types'\nimport toSnakeCase from 'to-snake-case'\n\nimport type { GenericColumns, GenericTable, PostgresAdapter } from '../types'\n\nimport { parentIDColumnMap } from './parentIDColumnMap'\nimport { traverseFields } from './traverseFields'\n\ntype Args = {\n  adapter: PostgresAdapter\n  baseColumns?: Record<string, PgColumnBuilder>\n  baseExtraConfig?: Record<string, (cols: GenericColumns) => IndexBuilder | UniqueConstraintBuilder>\n  buildRelationships?: boolean\n  disableUnique: boolean\n  fields: Field[]\n  rootRelationsToBuild?: Map<string, string>\n  rootTableIDColType?: string\n  rootTableName?: string\n  tableName: string\n  timestamps?: boolean\n}\n\ntype Result = {\n  relationsToBuild: Map<string, string>\n}\n\nexport const buildTable = ({\n  adapter,\n  baseColumns = {},\n  baseExtraConfig = {},\n  buildRelationships,\n  disableUnique = false,\n  fields,\n  rootRelationsToBuild,\n  rootTableIDColType,\n  rootTableName,\n  tableName,\n  timestamps,\n}: Args): Result => {\n  const columns: Record<string, PgColumnBuilder> = baseColumns\n  const indexes: Record<string, (cols: GenericColumns) => IndexBuilder> = {}\n\n  let hasLocalizedField = false\n  let hasLocalizedRelationshipField = false\n  let hasManyNumberField: 'index' | boolean = false\n  let hasLocalizedManyNumberField = false\n\n  const localesColumns: Record<string, PgColumnBuilder> = {}\n  const localesIndexes: Record<string, (cols: GenericColumns) => IndexBuilder> = {}\n  let localesTable: GenericTable\n  let numbersTable: GenericTable\n\n  const relationships: Set<string> = new Set()\n  let relationshipsTable: GenericTable\n\n  const relationsToBuild: Map<string, string> = new Map()\n\n  const idField = fields.find((field) => fieldAffectsData(field) && field.name === 'id')\n  let idColType = 'integer'\n\n  if (idField) {\n    if (idField.type === 'number') {\n      idColType = 'numeric'\n      columns.id = numeric('id').primaryKey()\n    }\n\n    if (idField.type === 'text') {\n      idColType = 'varchar'\n      columns.id = varchar('id').primaryKey()\n    }\n  } else {\n    columns.id = serial('id').primaryKey()\n  }\n\n  ;({\n    hasLocalizedField,\n    hasLocalizedManyNumberField,\n    hasLocalizedRelationshipField,\n    hasManyNumberField,\n  } = traverseFields({\n    adapter,\n    buildRelationships,\n    columns,\n    disableUnique,\n    fields,\n    indexes,\n    localesColumns,\n    localesIndexes,\n    newTableName: tableName,\n    parentTableName: tableName,\n    relationsToBuild,\n    relationships,\n    rootRelationsToBuild: rootRelationsToBuild || relationsToBuild,\n    rootTableIDColType: rootTableIDColType || idColType,\n    rootTableName: rootTableName || tableName,\n  }))\n\n  if (timestamps) {\n    columns.createdAt = timestamp('created_at', {\n      mode: 'string',\n      precision: 3,\n      withTimezone: true,\n    })\n      .defaultNow()\n      .notNull()\n    columns.updatedAt = timestamp('updated_at', {\n      mode: 'string',\n      precision: 3,\n      withTimezone: true,\n    })\n      .defaultNow()\n      .notNull()\n  }\n\n  const table = pgTable(tableName, columns, (cols) => {\n    const extraConfig = Object.entries(baseExtraConfig).reduce((config, [key, func]) => {\n      config[key] = func(cols)\n      return config\n    }, {})\n\n    return Object.entries(indexes).reduce((acc, [colName, func]) => {\n      acc[colName] = func(cols)\n      return acc\n    }, extraConfig)\n  })\n\n  adapter.tables[tableName] = table\n\n  if (hasLocalizedField) {\n    const localeTableName = `${tableName}_locales`\n    localesColumns.id = serial('id').primaryKey()\n    localesColumns._locale = adapter.enums.enum__locales('_locale').notNull()\n    localesColumns._parentID = parentIDColumnMap[idColType]('_parent_id')\n      .references(() => table.id, { onDelete: 'cascade' })\n      .notNull()\n\n    localesTable = pgTable(localeTableName, localesColumns, (cols) => {\n      return Object.entries(localesIndexes).reduce(\n        (acc, [colName, func]) => {\n          acc[colName] = func(cols)\n          return acc\n        },\n        {\n          _localeParent: unique().on(cols._locale, cols._parentID),\n        },\n      )\n    })\n\n    adapter.tables[localeTableName] = localesTable\n\n    const localesTableRelations = relations(localesTable, ({ one }) => ({\n      _parentID: one(table, {\n        fields: [localesTable._parentID],\n        references: [table.id],\n      }),\n    }))\n\n    adapter.relations[`relations_${localeTableName}`] = localesTableRelations\n  }\n\n  if (hasManyNumberField) {\n    const numbersTableName = `${tableName}_numbers`\n    const columns: Record<string, PgColumnBuilder> = {\n      id: serial('id').primaryKey(),\n      number: numeric('number'),\n      order: integer('order').notNull(),\n      parent: parentIDColumnMap[idColType]('parent_id')\n        .references(() => table.id, { onDelete: 'cascade' })\n        .notNull(),\n      path: varchar('path').notNull(),\n    }\n\n    if (hasLocalizedManyNumberField) {\n      columns.locale = adapter.enums.enum__locales('locale')\n    }\n\n    numbersTable = pgTable(numbersTableName, columns, (cols) => {\n      const indexes: Record<string, IndexBuilder> = {\n        orderParentIdx: index('order_parent_idx').on(cols.order, cols.parent),\n      }\n\n      if (hasManyNumberField === 'index') {\n        indexes.numberIdx = index('number_idx').on(cols.number)\n      }\n\n      if (hasLocalizedManyNumberField) {\n        indexes.localeParent = index('locale_parent').on(cols.locale, cols.parent)\n      }\n\n      return indexes\n    })\n\n    adapter.tables[numbersTableName] = numbersTable\n\n    const numbersTableRelations = relations(numbersTable, ({ one }) => ({\n      parent: one(table, {\n        fields: [numbersTable.parent],\n        references: [table.id],\n      }),\n    }))\n\n    adapter.relations[`relations_${numbersTableName}`] = numbersTableRelations\n  }\n\n  if (buildRelationships) {\n    if (relationships.size) {\n      const relationshipColumns: Record<string, PgColumnBuilder> = {\n        id: serial('id').primaryKey(),\n        order: integer('order'),\n        parent: parentIDColumnMap[idColType]('parent_id')\n          .references(() => table.id, { onDelete: 'cascade' })\n          .notNull(),\n        path: varchar('path').notNull(),\n      }\n\n      if (hasLocalizedRelationshipField) {\n        relationshipColumns.locale = adapter.enums.enum__locales('locale')\n      }\n\n      relationships.forEach((relationTo) => {\n        const formattedRelationTo = toSnakeCase(relationTo)\n        let colType = 'integer'\n        const relatedCollectionCustomID = adapter.payload.collections[\n          relationTo\n        ].config.fields.find((field) => fieldAffectsData(field) && field.name === 'id')\n        if (relatedCollectionCustomID?.type === 'number') colType = 'numeric'\n        if (relatedCollectionCustomID?.type === 'text') colType = 'varchar'\n\n        relationshipColumns[`${relationTo}ID`] = parentIDColumnMap[colType](\n          `${formattedRelationTo}_id`,\n        ).references(() => adapter.tables[formattedRelationTo].id, { onDelete: 'cascade' })\n      })\n\n      const relationshipsTableName = `${tableName}_relationships`\n\n      relationshipsTable = pgTable(relationshipsTableName, relationshipColumns, (cols) => {\n        const result: Record<string, unknown> = {}\n\n        if (hasLocalizedRelationshipField) {\n          result.localeIdx = index('locale_idx').on(cols.locale)\n          result.parentPathOrderLocale = unique().on(\n            cols.parent,\n            cols.path,\n            cols.order,\n            cols.locale,\n          )\n        } else {\n          result.parentPathOrder = unique().on(cols.parent, cols.path, cols.order)\n        }\n\n        return result\n      })\n\n      adapter.tables[relationshipsTableName] = relationshipsTable\n\n      const relationshipsTableRelations = relations(relationshipsTable, ({ one }) => {\n        const result: Record<string, Relation<string>> = {\n          parent: one(table, {\n            fields: [relationshipsTable.parent],\n            references: [table.id],\n            relationName: '_relationships',\n          }),\n        }\n\n        relationships.forEach((relationTo) => {\n          const relatedTableName = toSnakeCase(relationTo)\n          const idColumnName = `${relationTo}ID`\n          result[idColumnName] = one(adapter.tables[relatedTableName], {\n            fields: [relationshipsTable[idColumnName]],\n            references: [adapter.tables[relatedTableName].id],\n          })\n        })\n\n        return result\n      })\n\n      adapter.relations[`relations_${relationshipsTableName}`] = relationshipsTableRelations\n    }\n  }\n\n  const tableRelations = relations(table, ({ many }) => {\n    const result: Record<string, Relation<string>> = {}\n\n    relationsToBuild.forEach((val, key) => {\n      result[key] = many(adapter.tables[val])\n    })\n\n    if (hasLocalizedField) {\n      result._locales = many(localesTable)\n    }\n\n    if (hasManyNumberField) {\n      result._numbers = many(numbersTable)\n    }\n\n    if (relationships.size && relationshipsTable) {\n      result._relationships = many(relationshipsTable, {\n        relationName: '_relationships',\n      })\n    }\n\n    return result\n  })\n\n  adapter.relations[`relations_${tableName}`] = tableRelations\n\n  return { relationsToBuild }\n}\n"],"names":["buildTable","adapter","baseColumns","baseExtraConfig","buildRelationships","disableUnique","fields","rootRelationsToBuild","rootTableIDColType","rootTableName","tableName","timestamps","columns","indexes","hasLocalizedField","hasLocalizedRelationshipField","hasManyNumberField","hasLocalizedManyNumberField","localesColumns","localesIndexes","localesTable","numbersTable","relationships","Set","relationshipsTable","relationsToBuild","Map","idField","find","field","fieldAffectsData","name","idColType","type","id","numeric","primaryKey","varchar","serial","traverseFields","newTableName","parentTableName","createdAt","timestamp","mode","precision","withTimezone","defaultNow","notNull","updatedAt","table","pgTable","cols","extraConfig","Object","entries","reduce","config","key","func","acc","colName","tables","localeTableName","_locale","enums","enum__locales","_parentID","parentIDColumnMap","references","onDelete","_localeParent","unique","on","localesTableRelations","relations","one","numbersTableName","number","order","integer","parent","path","locale","orderParentIdx","index","numberIdx","localeParent","numbersTableRelations","size","relationshipColumns","forEach","relationTo","formattedRelationTo","toSnakeCase","colType","relatedCollectionCustomID","payload","collections","relationshipsTableName","result","localeIdx","parentPathOrderLocale","parentPathOrder","relationshipsTableRelations","relationName","relatedTableName","idColumnName","tableRelations","many","val","_locales","_numbers","_relationships"],"mappings":"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"}
@@ -0,0 +1,19 @@
1
+ /* eslint-disable no-param-reassign */ "use strict";
2
+ Object.defineProperty(exports, "__esModule", {
3
+ value: true
4
+ });
5
+ Object.defineProperty(exports, "createIndex", {
6
+ enumerable: true,
7
+ get: function() {
8
+ return createIndex;
9
+ }
10
+ });
11
+ const _pgcore = require("drizzle-orm/pg-core");
12
+ const createIndex = ({ name, columnName, unique })=>{
13
+ return (table)=>{
14
+ if (unique) return (0, _pgcore.uniqueIndex)(`${columnName}_idx`).on(table[name]);
15
+ return (0, _pgcore.index)(`${columnName}_idx`).on(table[name]);
16
+ };
17
+ };
18
+
19
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9zY2hlbWEvY3JlYXRlSW5kZXgudHMiXSwic291cmNlc0NvbnRlbnQiOlsiLyogZXNsaW50LWRpc2FibGUgbm8tcGFyYW0tcmVhc3NpZ24gKi9cbmltcG9ydCB7IGluZGV4LCB1bmlxdWVJbmRleCB9IGZyb20gJ2RyaXp6bGUtb3JtL3BnLWNvcmUnXG5cbmltcG9ydCB0eXBlIHsgR2VuZXJpY0NvbHVtbiB9IGZyb20gJy4uL3R5cGVzJ1xuXG50eXBlIENyZWF0ZUluZGV4QXJncyA9IHtcbiAgY29sdW1uTmFtZTogc3RyaW5nXG4gIG5hbWU6IHN0cmluZ1xuICB1bmlxdWU/OiBib29sZWFuXG59XG5cbmV4cG9ydCBjb25zdCBjcmVhdGVJbmRleCA9ICh7IG5hbWUsIGNvbHVtbk5hbWUsIHVuaXF1ZSB9OiBDcmVhdGVJbmRleEFyZ3MpID0+IHtcbiAgcmV0dXJuICh0YWJsZTogeyBbeDogc3RyaW5nXTogR2VuZXJpY0NvbHVtbiB9KSA9PiB7XG4gICAgaWYgKHVuaXF1ZSkgcmV0dXJuIHVuaXF1ZUluZGV4KGAke2NvbHVtbk5hbWV9X2lkeGApLm9uKHRhYmxlW25hbWVdKVxuICAgIHJldHVybiBpbmRleChgJHtjb2x1bW5OYW1lfV9pZHhgKS5vbih0YWJsZVtuYW1lXSlcbiAgfVxufVxuIl0sIm5hbWVzIjpbImNyZWF0ZUluZGV4IiwibmFtZSIsImNvbHVtbk5hbWUiLCJ1bmlxdWUiLCJ0YWJsZSIsInVuaXF1ZUluZGV4Iiwib24iLCJpbmRleCJdLCJtYXBwaW5ncyI6IkFBQUEsb0NBQW9DOzs7OytCQVd2QkE7OztlQUFBQTs7O3dCQVZzQjtBQVU1QixNQUFNQSxjQUFjLENBQUMsRUFBRUMsSUFBSSxFQUFFQyxVQUFVLEVBQUVDLE1BQU0sRUFBbUI7SUFDdkUsT0FBTyxDQUFDQztRQUNOLElBQUlELFFBQVEsT0FBT0UsSUFBQUEsbUJBQVcsRUFBQyxDQUFDLEVBQUVILFdBQVcsSUFBSSxDQUFDLEVBQUVJLEVBQUUsQ0FBQ0YsS0FBSyxDQUFDSCxLQUFLO1FBQ2xFLE9BQU9NLElBQUFBLGFBQUssRUFBQyxDQUFDLEVBQUVMLFdBQVcsSUFBSSxDQUFDLEVBQUVJLEVBQUUsQ0FBQ0YsS0FBSyxDQUFDSCxLQUFLO0lBQ2xEO0FBQ0YifQ==
@@ -0,0 +1,18 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", {
3
+ value: true
4
+ });
5
+ Object.defineProperty(exports, "parentIDColumnMap", {
6
+ enumerable: true,
7
+ get: function() {
8
+ return parentIDColumnMap;
9
+ }
10
+ });
11
+ const _pgcore = require("drizzle-orm/pg-core");
12
+ const parentIDColumnMap = {
13
+ integer: _pgcore.integer,
14
+ numeric: _pgcore.numeric,
15
+ varchar: _pgcore.varchar
16
+ };
17
+
18
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9zY2hlbWEvcGFyZW50SURDb2x1bW5NYXAudHMiXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgaW50ZWdlciwgbnVtZXJpYywgdmFyY2hhciB9IGZyb20gJ2RyaXp6bGUtb3JtL3BnLWNvcmUnXG5cbmV4cG9ydCBjb25zdCBwYXJlbnRJRENvbHVtbk1hcCA9IHtcbiAgaW50ZWdlcixcbiAgbnVtZXJpYyxcbiAgdmFyY2hhcixcbn1cbiJdLCJuYW1lcyI6WyJwYXJlbnRJRENvbHVtbk1hcCIsImludGVnZXIiLCJudW1lcmljIiwidmFyY2hhciJdLCJtYXBwaW5ncyI6Ijs7OzsrQkFFYUE7OztlQUFBQTs7O3dCQUY2QjtBQUVuQyxNQUFNQSxvQkFBb0I7SUFDL0JDLFNBQUFBLGVBQU87SUFDUEMsU0FBQUEsZUFBTztJQUNQQyxTQUFBQSxlQUFPO0FBQ1QifQ==