@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.
- package/dist/connect.js +82 -0
- package/dist/create.js +32 -0
- package/dist/createGlobal.js +32 -0
- package/dist/createGlobalVersion.js +48 -0
- package/dist/createMigration.js +85 -0
- package/dist/createVersion.js +54 -0
- package/dist/deleteMany.js +44 -0
- package/dist/deleteOne.js +47 -0
- package/dist/deleteVersions.js +46 -0
- package/dist/destroy.js +16 -0
- package/dist/find/buildFindManyArgs.js +61 -0
- package/dist/find/chainMethods.js +21 -0
- package/dist/find/findMany.js +197 -0
- package/dist/find/traverseFields.js +118 -0
- package/dist/find.js +35 -0
- package/dist/findGlobal.js +38 -0
- package/dist/findGlobalVersions.js +39 -0
- package/dist/findOne.js +49 -0
- package/dist/findVersions.js +39 -0
- package/dist/index.js +95 -0
- package/dist/init.js +74 -0
- package/dist/migrate.js +81 -0
- package/dist/migrateStatus.js +54 -0
- package/dist/mock.js +13 -0
- package/dist/queries/buildAndOrConditions.js +39 -0
- package/dist/queries/buildQuery.js +80 -0
- package/dist/queries/createJSONQuery/convertPathToJSONTraversal.js +24 -0
- package/dist/queries/createJSONQuery/formatJSONPathSegment.js +15 -0
- package/dist/queries/createJSONQuery/index.js +64 -0
- package/dist/queries/getTableColumnFromPath.js +333 -0
- package/dist/queries/operatorMap.js +34 -0
- package/dist/queries/parseParams.js +146 -0
- package/dist/queries/sanitizeQueryValue.js +79 -0
- package/dist/queryDrafts.js +56 -0
- package/dist/reference.js +76 -0
- package/dist/schema/build.js +245 -0
- package/dist/schema/createIndex.js +19 -0
- package/dist/schema/parentIDColumnMap.js +18 -0
- package/dist/schema/traverseFields.js +430 -0
- package/dist/schema/validateExistingBlockIsIdentical.js +34 -0
- package/dist/transactions/beginTransaction.js +51 -0
- package/dist/transactions/commitTransaction.js +24 -0
- package/dist/transactions/rollbackTransaction.js +20 -0
- package/dist/transform/read/hasManyNumber.js +20 -0
- package/dist/transform/read/index.js +42 -0
- package/dist/transform/read/relationship.js +74 -0
- package/dist/transform/read/traverseFields.js +325 -0
- package/dist/transform/write/array.js +55 -0
- package/dist/transform/write/blocks.js +56 -0
- package/dist/transform/write/index.js +46 -0
- package/dist/transform/write/numbers.js +21 -0
- package/dist/transform/write/relationships.js +33 -0
- package/dist/transform/write/selects.js +29 -0
- package/dist/transform/write/traverseFields.js +379 -0
- package/dist/transform/write/types.js +6 -0
- package/dist/types.js +6 -0
- package/dist/update.js +48 -0
- package/dist/updateGlobal.js +39 -0
- package/dist/updateGlobalVersion.js +50 -0
- package/dist/updateVersion.js +50 -0
- package/dist/upsertRow/deleteExistingArrayRows.js +20 -0
- package/dist/upsertRow/deleteExistingRowsByPath.js +43 -0
- package/dist/upsertRow/index.js +243 -0
- package/dist/upsertRow/insertArrays.js +64 -0
- package/dist/upsertRow/types.js +6 -0
- package/dist/utilities/appendPrefixToKeys.js +16 -0
- package/dist/utilities/createBlocksMap.js +39 -0
- package/dist/utilities/createMigrationTable.js +23 -0
- package/dist/utilities/createRelationshipMap.js +29 -0
- package/dist/utilities/hasLocalesTable.js +21 -0
- package/dist/utilities/isArrayOfRows.js +15 -0
- package/dist/utilities/migrationTableExists.js +19 -0
- package/dist/webpack.js +30 -0
- 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==
|