@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
package/dist/update.js
ADDED
@@ -0,0 +1,48 @@
|
|
1
|
+
"use strict";
|
2
|
+
Object.defineProperty(exports, "__esModule", {
|
3
|
+
value: true
|
4
|
+
});
|
5
|
+
Object.defineProperty(exports, "updateOne", {
|
6
|
+
enumerable: true,
|
7
|
+
get: function() {
|
8
|
+
return updateOne;
|
9
|
+
}
|
10
|
+
});
|
11
|
+
const _tosnakecase = /*#__PURE__*/ _interop_require_default(require("to-snake-case"));
|
12
|
+
const _buildQuery = /*#__PURE__*/ _interop_require_default(require("./queries/buildQuery"));
|
13
|
+
const _upsertRow = require("./upsertRow");
|
14
|
+
function _interop_require_default(obj) {
|
15
|
+
return obj && obj.__esModule ? obj : {
|
16
|
+
default: obj
|
17
|
+
};
|
18
|
+
}
|
19
|
+
const updateOne = async function updateOne({ id, collection: collectionSlug, data, draft, locale, req, where: whereArg }) {
|
20
|
+
const db = this.sessions[req.transactionID]?.db || this.db;
|
21
|
+
const collection = this.payload.collections[collectionSlug].config;
|
22
|
+
const tableName = (0, _tosnakecase.default)(collectionSlug);
|
23
|
+
const whereToUse = whereArg || {
|
24
|
+
id: {
|
25
|
+
equals: id
|
26
|
+
}
|
27
|
+
};
|
28
|
+
const { where } = await (0, _buildQuery.default)({
|
29
|
+
adapter: this,
|
30
|
+
fields: collection.fields,
|
31
|
+
locale,
|
32
|
+
tableName,
|
33
|
+
where: whereToUse
|
34
|
+
});
|
35
|
+
const result = await (0, _upsertRow.upsertRow)({
|
36
|
+
id,
|
37
|
+
adapter: this,
|
38
|
+
data,
|
39
|
+
db,
|
40
|
+
fields: collection.fields,
|
41
|
+
operation: 'update',
|
42
|
+
tableName: (0, _tosnakecase.default)(collectionSlug),
|
43
|
+
where
|
44
|
+
});
|
45
|
+
return result;
|
46
|
+
};
|
47
|
+
|
48
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uL3NyYy91cGRhdGUudHMiXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHR5cGUgeyBVcGRhdGVPbmUgfSBmcm9tICdwYXlsb2FkL2RhdGFiYXNlJ1xuXG5pbXBvcnQgdG9TbmFrZUNhc2UgZnJvbSAndG8tc25ha2UtY2FzZSdcblxuaW1wb3J0IHR5cGUgeyBQb3N0Z3Jlc0FkYXB0ZXIgfSBmcm9tICcuL3R5cGVzJ1xuXG5pbXBvcnQgYnVpbGRRdWVyeSBmcm9tICcuL3F1ZXJpZXMvYnVpbGRRdWVyeSdcbmltcG9ydCB7IHVwc2VydFJvdyB9IGZyb20gJy4vdXBzZXJ0Um93J1xuXG5leHBvcnQgY29uc3QgdXBkYXRlT25lOiBVcGRhdGVPbmUgPSBhc3luYyBmdW5jdGlvbiB1cGRhdGVPbmUgKFxuICB0aGlzOiBQb3N0Z3Jlc0FkYXB0ZXIsXG4gIHsgaWQsIGNvbGxlY3Rpb246IGNvbGxlY3Rpb25TbHVnLCBkYXRhLCBkcmFmdCwgbG9jYWxlLCByZXEsIHdoZXJlOiB3aGVyZUFyZyB9LFxuKSB7XG4gIGNvbnN0IGRiID0gdGhpcy5zZXNzaW9uc1tyZXEudHJhbnNhY3Rpb25JRF0/LmRiIHx8IHRoaXMuZGJcbiAgY29uc3QgY29sbGVjdGlvbiA9IHRoaXMucGF5bG9hZC5jb2xsZWN0aW9uc1tjb2xsZWN0aW9uU2x1Z10uY29uZmlnXG4gIGNvbnN0IHRhYmxlTmFtZSA9IHRvU25ha2VDYXNlKGNvbGxlY3Rpb25TbHVnKVxuICBjb25zdCB3aGVyZVRvVXNlID0gd2hlcmVBcmcgfHwgeyBpZDogeyBlcXVhbHM6IGlkIH0gfVxuXG4gIGNvbnN0IHsgd2hlcmUgfSA9IGF3YWl0IGJ1aWxkUXVlcnkoe1xuICAgIGFkYXB0ZXI6IHRoaXMsXG4gICAgZmllbGRzOiBjb2xsZWN0aW9uLmZpZWxkcyxcbiAgICBsb2NhbGUsXG4gICAgdGFibGVOYW1lLFxuICAgIHdoZXJlOiB3aGVyZVRvVXNlLFxuICB9KVxuXG4gIGNvbnN0IHJlc3VsdCA9IGF3YWl0IHVwc2VydFJvdyh7XG4gICAgaWQsXG4gICAgYWRhcHRlcjogdGhpcyxcbiAgICBkYXRhLFxuICAgIGRiLFxuICAgIGZpZWxkczogY29sbGVjdGlvbi5maWVsZHMsXG4gICAgb3BlcmF0aW9uOiAndXBkYXRlJyxcbiAgICB0YWJsZU5hbWU6IHRvU25ha2VDYXNlKGNvbGxlY3Rpb25TbHVnKSxcbiAgICB3aGVyZSxcbiAgfSlcblxuICByZXR1cm4gcmVzdWx0XG59XG4iXSwibmFtZXMiOlsidXBkYXRlT25lIiwiaWQiLCJjb2xsZWN0aW9uIiwiY29sbGVjdGlvblNsdWciLCJkYXRhIiwiZHJhZnQiLCJsb2NhbGUiLCJyZXEiLCJ3aGVyZSIsIndoZXJlQXJnIiwiZGIiLCJzZXNzaW9ucyIsInRyYW5zYWN0aW9uSUQiLCJwYXlsb2FkIiwiY29sbGVjdGlvbnMiLCJjb25maWciLCJ0YWJsZU5hbWUiLCJ0b1NuYWtlQ2FzZSIsIndoZXJlVG9Vc2UiLCJlcXVhbHMiLCJidWlsZFF1ZXJ5IiwiYWRhcHRlciIsImZpZWxkcyIsInJlc3VsdCIsInVwc2VydFJvdyIsIm9wZXJhdGlvbiJdLCJtYXBwaW5ncyI6Ijs7OzsrQkFTYUE7OztlQUFBQTs7O29FQVBXO21FQUlEOzJCQUNHOzs7Ozs7QUFFbkIsTUFBTUEsWUFBdUIsZUFBZUEsVUFFakQsRUFBRUMsRUFBRSxFQUFFQyxZQUFZQyxjQUFjLEVBQUVDLElBQUksRUFBRUMsS0FBSyxFQUFFQyxNQUFNLEVBQUVDLEdBQUcsRUFBRUMsT0FBT0MsUUFBUSxFQUFFO0lBRTdFLE1BQU1DLEtBQUssSUFBSSxDQUFDQyxRQUFRLENBQUNKLElBQUlLLGFBQWEsQ0FBQyxFQUFFRixNQUFNLElBQUksQ0FBQ0EsRUFBRTtJQUMxRCxNQUFNUixhQUFhLElBQUksQ0FBQ1csT0FBTyxDQUFDQyxXQUFXLENBQUNYLGVBQWUsQ0FBQ1ksTUFBTTtJQUNsRSxNQUFNQyxZQUFZQyxJQUFBQSxvQkFBVyxFQUFDZDtJQUM5QixNQUFNZSxhQUFhVCxZQUFZO1FBQUVSLElBQUk7WUFBRWtCLFFBQVFsQjtRQUFHO0lBQUU7SUFFcEQsTUFBTSxFQUFFTyxLQUFLLEVBQUUsR0FBRyxNQUFNWSxJQUFBQSxtQkFBVSxFQUFDO1FBQ2pDQyxTQUFTLElBQUk7UUFDYkMsUUFBUXBCLFdBQVdvQixNQUFNO1FBQ3pCaEI7UUFDQVU7UUFDQVIsT0FBT1U7SUFDVDtJQUVBLE1BQU1LLFNBQVMsTUFBTUMsSUFBQUEsb0JBQVMsRUFBQztRQUM3QnZCO1FBQ0FvQixTQUFTLElBQUk7UUFDYmpCO1FBQ0FNO1FBQ0FZLFFBQVFwQixXQUFXb0IsTUFBTTtRQUN6QkcsV0FBVztRQUNYVCxXQUFXQyxJQUFBQSxvQkFBVyxFQUFDZDtRQUN2Qks7SUFDRjtJQUVBLE9BQU9lO0FBQ1QifQ==
|
@@ -0,0 +1,39 @@
|
|
1
|
+
"use strict";
|
2
|
+
Object.defineProperty(exports, "__esModule", {
|
3
|
+
value: true
|
4
|
+
});
|
5
|
+
Object.defineProperty(exports, "updateGlobal", {
|
6
|
+
enumerable: true,
|
7
|
+
get: function() {
|
8
|
+
return updateGlobal;
|
9
|
+
}
|
10
|
+
});
|
11
|
+
const _tosnakecase = /*#__PURE__*/ _interop_require_default(require("to-snake-case"));
|
12
|
+
const _upsertRow = require("./upsertRow");
|
13
|
+
function _interop_require_default(obj) {
|
14
|
+
return obj && obj.__esModule ? obj : {
|
15
|
+
default: obj
|
16
|
+
};
|
17
|
+
}
|
18
|
+
async function updateGlobal({ data, req = {}, slug }) {
|
19
|
+
const db = this.sessions[req.transactionID]?.db || this.db;
|
20
|
+
const globalConfig = this.payload.globals.config.find((config)=>config.slug === slug);
|
21
|
+
const tableName = (0, _tosnakecase.default)(slug);
|
22
|
+
const existingGlobal = await db.query[tableName].findFirst({});
|
23
|
+
const result = await (0, _upsertRow.upsertRow)({
|
24
|
+
...existingGlobal ? {
|
25
|
+
id: existingGlobal.id,
|
26
|
+
operation: 'update'
|
27
|
+
} : {
|
28
|
+
operation: 'create'
|
29
|
+
},
|
30
|
+
adapter: this,
|
31
|
+
data,
|
32
|
+
db,
|
33
|
+
fields: globalConfig.fields,
|
34
|
+
tableName
|
35
|
+
});
|
36
|
+
return result;
|
37
|
+
}
|
38
|
+
|
39
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uL3NyYy91cGRhdGVHbG9iYWwudHMiXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHR5cGUgeyBVcGRhdGVHbG9iYWxBcmdzIH0gZnJvbSAncGF5bG9hZC9kYXRhYmFzZSdcbmltcG9ydCB0eXBlIHsgUGF5bG9hZFJlcXVlc3QsIFR5cGVXaXRoSUQgfSBmcm9tICdwYXlsb2FkL3R5cGVzJ1xuXG5pbXBvcnQgdG9TbmFrZUNhc2UgZnJvbSAndG8tc25ha2UtY2FzZSdcblxuaW1wb3J0IHR5cGUgeyBQb3N0Z3Jlc0FkYXB0ZXIgfSBmcm9tICcuL3R5cGVzJ1xuXG5pbXBvcnQgeyB1cHNlcnRSb3cgfSBmcm9tICcuL3Vwc2VydFJvdydcblxuZXhwb3J0IGFzeW5jIGZ1bmN0aW9uIHVwZGF0ZUdsb2JhbDxUIGV4dGVuZHMgVHlwZVdpdGhJRD4oXG4gIHRoaXM6IFBvc3RncmVzQWRhcHRlcixcbiAgeyBkYXRhLCByZXEgPSB7fSBhcyBQYXlsb2FkUmVxdWVzdCwgc2x1ZyB9OiBVcGRhdGVHbG9iYWxBcmdzLFxuKTogUHJvbWlzZTxUPiB7XG4gIGNvbnN0IGRiID0gdGhpcy5zZXNzaW9uc1tyZXEudHJhbnNhY3Rpb25JRF0/LmRiIHx8IHRoaXMuZGJcbiAgY29uc3QgZ2xvYmFsQ29uZmlnID0gdGhpcy5wYXlsb2FkLmdsb2JhbHMuY29uZmlnLmZpbmQoKGNvbmZpZykgPT4gY29uZmlnLnNsdWcgPT09IHNsdWcpXG4gIGNvbnN0IHRhYmxlTmFtZSA9IHRvU25ha2VDYXNlKHNsdWcpXG5cbiAgY29uc3QgZXhpc3RpbmdHbG9iYWwgPSBhd2FpdCBkYi5xdWVyeVt0YWJsZU5hbWVdLmZpbmRGaXJzdCh7fSlcblxuICBjb25zdCByZXN1bHQgPSBhd2FpdCB1cHNlcnRSb3c8VD4oe1xuICAgIC4uLihleGlzdGluZ0dsb2JhbCA/IHsgaWQ6IGV4aXN0aW5nR2xvYmFsLmlkLCBvcGVyYXRpb246ICd1cGRhdGUnIH0gOiB7IG9wZXJhdGlvbjogJ2NyZWF0ZScgfSksXG4gICAgYWRhcHRlcjogdGhpcyxcbiAgICBkYXRhLFxuICAgIGRiLFxuICAgIGZpZWxkczogZ2xvYmFsQ29uZmlnLmZpZWxkcyxcbiAgICB0YWJsZU5hbWUsXG4gIH0pXG5cbiAgcmV0dXJuIHJlc3VsdFxufVxuIl0sIm5hbWVzIjpbInVwZGF0ZUdsb2JhbCIsImRhdGEiLCJyZXEiLCJzbHVnIiwiZGIiLCJzZXNzaW9ucyIsInRyYW5zYWN0aW9uSUQiLCJnbG9iYWxDb25maWciLCJwYXlsb2FkIiwiZ2xvYmFscyIsImNvbmZpZyIsImZpbmQiLCJ0YWJsZU5hbWUiLCJ0b1NuYWtlQ2FzZSIsImV4aXN0aW5nR2xvYmFsIiwicXVlcnkiLCJmaW5kRmlyc3QiLCJyZXN1bHQiLCJ1cHNlcnRSb3ciLCJpZCIsIm9wZXJhdGlvbiIsImFkYXB0ZXIiLCJmaWVsZHMiXSwibWFwcGluZ3MiOiI7Ozs7K0JBU3NCQTs7O2VBQUFBOzs7b0VBTkU7MkJBSUU7Ozs7OztBQUVuQixlQUFlQSxhQUVwQixFQUFFQyxJQUFJLEVBQUVDLE1BQU0sQ0FBQyxDQUFtQixFQUFFQyxJQUFJLEVBQW9CO0lBRTVELE1BQU1DLEtBQUssSUFBSSxDQUFDQyxRQUFRLENBQUNILElBQUlJLGFBQWEsQ0FBQyxFQUFFRixNQUFNLElBQUksQ0FBQ0EsRUFBRTtJQUMxRCxNQUFNRyxlQUFlLElBQUksQ0FBQ0MsT0FBTyxDQUFDQyxPQUFPLENBQUNDLE1BQU0sQ0FBQ0MsSUFBSSxDQUFDLENBQUNELFNBQVdBLE9BQU9QLElBQUksS0FBS0E7SUFDbEYsTUFBTVMsWUFBWUMsSUFBQUEsb0JBQVcsRUFBQ1Y7SUFFOUIsTUFBTVcsaUJBQWlCLE1BQU1WLEdBQUdXLEtBQUssQ0FBQ0gsVUFBVSxDQUFDSSxTQUFTLENBQUMsQ0FBQztJQUU1RCxNQUFNQyxTQUFTLE1BQU1DLElBQUFBLG9CQUFTLEVBQUk7UUFDaEMsR0FBSUosaUJBQWlCO1lBQUVLLElBQUlMLGVBQWVLLEVBQUU7WUFBRUMsV0FBVztRQUFTLElBQUk7WUFBRUEsV0FBVztRQUFTLENBQUM7UUFDN0ZDLFNBQVMsSUFBSTtRQUNicEI7UUFDQUc7UUFDQWtCLFFBQVFmLGFBQWFlLE1BQU07UUFDM0JWO0lBQ0Y7SUFFQSxPQUFPSztBQUNUIn0=
|
@@ -0,0 +1,50 @@
|
|
1
|
+
"use strict";
|
2
|
+
Object.defineProperty(exports, "__esModule", {
|
3
|
+
value: true
|
4
|
+
});
|
5
|
+
Object.defineProperty(exports, "updateGlobalVersion", {
|
6
|
+
enumerable: true,
|
7
|
+
get: function() {
|
8
|
+
return updateGlobalVersion;
|
9
|
+
}
|
10
|
+
});
|
11
|
+
const _versions = require("payload/versions");
|
12
|
+
const _tosnakecase = /*#__PURE__*/ _interop_require_default(require("to-snake-case"));
|
13
|
+
const _buildQuery = /*#__PURE__*/ _interop_require_default(require("./queries/buildQuery"));
|
14
|
+
const _upsertRow = require("./upsertRow");
|
15
|
+
function _interop_require_default(obj) {
|
16
|
+
return obj && obj.__esModule ? obj : {
|
17
|
+
default: obj
|
18
|
+
};
|
19
|
+
}
|
20
|
+
async function updateGlobalVersion({ id, global, locale, req = {}, versionData, where: whereArg }) {
|
21
|
+
const db = this.sessions[req.transactionID]?.db || this.db;
|
22
|
+
const globalConfig = this.payload.globals.config.find(({ slug })=>slug === global);
|
23
|
+
const whereToUse = whereArg || {
|
24
|
+
id: {
|
25
|
+
equals: id
|
26
|
+
}
|
27
|
+
};
|
28
|
+
const tableName = `_${(0, _tosnakecase.default)(global)}_v`;
|
29
|
+
const fields = (0, _versions.buildVersionGlobalFields)(globalConfig);
|
30
|
+
const { where } = await (0, _buildQuery.default)({
|
31
|
+
adapter: this,
|
32
|
+
fields,
|
33
|
+
locale,
|
34
|
+
tableName,
|
35
|
+
where: whereToUse
|
36
|
+
});
|
37
|
+
const result = await (0, _upsertRow.upsertRow)({
|
38
|
+
id,
|
39
|
+
adapter: this,
|
40
|
+
data: versionData,
|
41
|
+
db,
|
42
|
+
fields,
|
43
|
+
operation: 'update',
|
44
|
+
tableName,
|
45
|
+
where
|
46
|
+
});
|
47
|
+
return result;
|
48
|
+
}
|
49
|
+
|
50
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uL3NyYy91cGRhdGVHbG9iYWxWZXJzaW9uLnRzIl0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB0eXBlIHsgVHlwZVdpdGhWZXJzaW9uIH0gZnJvbSAncGF5bG9hZC9kYXRhYmFzZSdcbmltcG9ydCB0eXBlIHsgVXBkYXRlR2xvYmFsVmVyc2lvbkFyZ3MgfSBmcm9tICdwYXlsb2FkL2RhdGFiYXNlJ1xuaW1wb3J0IHR5cGUgeyBQYXlsb2FkUmVxdWVzdCwgU2FuaXRpemVkR2xvYmFsQ29uZmlnLCBUeXBlV2l0aElEIH0gZnJvbSAncGF5bG9hZC90eXBlcydcblxuaW1wb3J0IHsgYnVpbGRWZXJzaW9uR2xvYmFsRmllbGRzIH0gZnJvbSAncGF5bG9hZC92ZXJzaW9ucydcbmltcG9ydCB0b1NuYWtlQ2FzZSBmcm9tICd0by1zbmFrZS1jYXNlJ1xuXG5pbXBvcnQgdHlwZSB7IFBvc3RncmVzQWRhcHRlciB9IGZyb20gJy4vdHlwZXMnXG5cbmltcG9ydCBidWlsZFF1ZXJ5IGZyb20gJy4vcXVlcmllcy9idWlsZFF1ZXJ5J1xuaW1wb3J0IHsgdXBzZXJ0Um93IH0gZnJvbSAnLi91cHNlcnRSb3cnXG5cbmV4cG9ydCBhc3luYyBmdW5jdGlvbiB1cGRhdGVHbG9iYWxWZXJzaW9uPFQgZXh0ZW5kcyBUeXBlV2l0aElEPihcbiAgdGhpczogUG9zdGdyZXNBZGFwdGVyLFxuICB7XG4gICAgaWQsXG4gICAgZ2xvYmFsLFxuICAgIGxvY2FsZSxcbiAgICByZXEgPSB7fSBhcyBQYXlsb2FkUmVxdWVzdCxcbiAgICB2ZXJzaW9uRGF0YSxcbiAgICB3aGVyZTogd2hlcmVBcmcsXG4gIH06IFVwZGF0ZUdsb2JhbFZlcnNpb25BcmdzPFQ+LFxuKSB7XG4gIGNvbnN0IGRiID0gdGhpcy5zZXNzaW9uc1tyZXEudHJhbnNhY3Rpb25JRF0/LmRiIHx8IHRoaXMuZGJcbiAgY29uc3QgZ2xvYmFsQ29uZmlnOiBTYW5pdGl6ZWRHbG9iYWxDb25maWcgPSB0aGlzLnBheWxvYWQuZ2xvYmFscy5jb25maWcuZmluZChcbiAgICAoeyBzbHVnIH0pID0+IHNsdWcgPT09IGdsb2JhbCxcbiAgKVxuICBjb25zdCB3aGVyZVRvVXNlID0gd2hlcmVBcmcgfHwgeyBpZDogeyBlcXVhbHM6IGlkIH0gfVxuICBjb25zdCB0YWJsZU5hbWUgPSBgXyR7dG9TbmFrZUNhc2UoZ2xvYmFsKX1fdmBcbiAgY29uc3QgZmllbGRzID0gYnVpbGRWZXJzaW9uR2xvYmFsRmllbGRzKGdsb2JhbENvbmZpZylcblxuICBjb25zdCB7IHdoZXJlIH0gPSBhd2FpdCBidWlsZFF1ZXJ5KHtcbiAgICBhZGFwdGVyOiB0aGlzLFxuICAgIGZpZWxkcyxcbiAgICBsb2NhbGUsXG4gICAgdGFibGVOYW1lLFxuICAgIHdoZXJlOiB3aGVyZVRvVXNlLFxuICB9KVxuXG4gIGNvbnN0IHJlc3VsdCA9IGF3YWl0IHVwc2VydFJvdzxUeXBlV2l0aFZlcnNpb248VD4+KHtcbiAgICBpZCxcbiAgICBhZGFwdGVyOiB0aGlzLFxuICAgIGRhdGE6IHZlcnNpb25EYXRhLFxuICAgIGRiLFxuICAgIGZpZWxkcyxcbiAgICBvcGVyYXRpb246ICd1cGRhdGUnLFxuICAgIHRhYmxlTmFtZSxcbiAgICB3aGVyZSxcbiAgfSlcblxuICByZXR1cm4gcmVzdWx0XG59XG4iXSwibmFtZXMiOlsidXBkYXRlR2xvYmFsVmVyc2lvbiIsImlkIiwiZ2xvYmFsIiwibG9jYWxlIiwicmVxIiwidmVyc2lvbkRhdGEiLCJ3aGVyZSIsIndoZXJlQXJnIiwiZGIiLCJzZXNzaW9ucyIsInRyYW5zYWN0aW9uSUQiLCJnbG9iYWxDb25maWciLCJwYXlsb2FkIiwiZ2xvYmFscyIsImNvbmZpZyIsImZpbmQiLCJzbHVnIiwid2hlcmVUb1VzZSIsImVxdWFscyIsInRhYmxlTmFtZSIsInRvU25ha2VDYXNlIiwiZmllbGRzIiwiYnVpbGRWZXJzaW9uR2xvYmFsRmllbGRzIiwiYnVpbGRRdWVyeSIsImFkYXB0ZXIiLCJyZXN1bHQiLCJ1cHNlcnRSb3ciLCJkYXRhIiwib3BlcmF0aW9uIl0sIm1hcHBpbmdzIjoiOzs7OytCQVlzQkE7OztlQUFBQTs7OzBCQVJtQjtvRUFDakI7bUVBSUQ7MkJBQ0c7Ozs7OztBQUVuQixlQUFlQSxvQkFFcEIsRUFDRUMsRUFBRSxFQUNGQyxNQUFNLEVBQ05DLE1BQU0sRUFDTkMsTUFBTSxDQUFDLENBQW1CLEVBQzFCQyxXQUFXLEVBQ1hDLE9BQU9DLFFBQVEsRUFDWTtJQUU3QixNQUFNQyxLQUFLLElBQUksQ0FBQ0MsUUFBUSxDQUFDTCxJQUFJTSxhQUFhLENBQUMsRUFBRUYsTUFBTSxJQUFJLENBQUNBLEVBQUU7SUFDMUQsTUFBTUcsZUFBc0MsSUFBSSxDQUFDQyxPQUFPLENBQUNDLE9BQU8sQ0FBQ0MsTUFBTSxDQUFDQyxJQUFJLENBQzFFLENBQUMsRUFBRUMsSUFBSSxFQUFFLEdBQUtBLFNBQVNkO0lBRXpCLE1BQU1lLGFBQWFWLFlBQVk7UUFBRU4sSUFBSTtZQUFFaUIsUUFBUWpCO1FBQUc7SUFBRTtJQUNwRCxNQUFNa0IsWUFBWSxDQUFDLENBQUMsRUFBRUMsSUFBQUEsb0JBQVcsRUFBQ2xCLFFBQVEsRUFBRSxDQUFDO0lBQzdDLE1BQU1tQixTQUFTQyxJQUFBQSxrQ0FBd0IsRUFBQ1g7SUFFeEMsTUFBTSxFQUFFTCxLQUFLLEVBQUUsR0FBRyxNQUFNaUIsSUFBQUEsbUJBQVUsRUFBQztRQUNqQ0MsU0FBUyxJQUFJO1FBQ2JIO1FBQ0FsQjtRQUNBZ0I7UUFDQWIsT0FBT1c7SUFDVDtJQUVBLE1BQU1RLFNBQVMsTUFBTUMsSUFBQUEsb0JBQVMsRUFBcUI7UUFDakR6QjtRQUNBdUIsU0FBUyxJQUFJO1FBQ2JHLE1BQU10QjtRQUNORztRQUNBYTtRQUNBTyxXQUFXO1FBQ1hUO1FBQ0FiO0lBQ0Y7SUFFQSxPQUFPbUI7QUFDVCJ9
|
@@ -0,0 +1,50 @@
|
|
1
|
+
"use strict";
|
2
|
+
Object.defineProperty(exports, "__esModule", {
|
3
|
+
value: true
|
4
|
+
});
|
5
|
+
Object.defineProperty(exports, "updateVersion", {
|
6
|
+
enumerable: true,
|
7
|
+
get: function() {
|
8
|
+
return updateVersion;
|
9
|
+
}
|
10
|
+
});
|
11
|
+
const _versions = require("payload/versions");
|
12
|
+
const _tosnakecase = /*#__PURE__*/ _interop_require_default(require("to-snake-case"));
|
13
|
+
const _buildQuery = /*#__PURE__*/ _interop_require_default(require("./queries/buildQuery"));
|
14
|
+
const _upsertRow = require("./upsertRow");
|
15
|
+
function _interop_require_default(obj) {
|
16
|
+
return obj && obj.__esModule ? obj : {
|
17
|
+
default: obj
|
18
|
+
};
|
19
|
+
}
|
20
|
+
async function updateVersion({ id, collection, locale, req = {}, versionData, where: whereArg }) {
|
21
|
+
const db = this.sessions[req.transactionID]?.db || this.db;
|
22
|
+
const collectionConfig = this.payload.collections[collection].config;
|
23
|
+
const whereToUse = whereArg || {
|
24
|
+
id: {
|
25
|
+
equals: id
|
26
|
+
}
|
27
|
+
};
|
28
|
+
const tableName = `_${(0, _tosnakecase.default)(collection)}_v`;
|
29
|
+
const fields = (0, _versions.buildVersionCollectionFields)(collectionConfig);
|
30
|
+
const { where } = await (0, _buildQuery.default)({
|
31
|
+
adapter: this,
|
32
|
+
fields,
|
33
|
+
locale,
|
34
|
+
tableName,
|
35
|
+
where: whereToUse
|
36
|
+
});
|
37
|
+
const result = await (0, _upsertRow.upsertRow)({
|
38
|
+
id,
|
39
|
+
adapter: this,
|
40
|
+
data: versionData,
|
41
|
+
db,
|
42
|
+
fields,
|
43
|
+
operation: 'update',
|
44
|
+
tableName,
|
45
|
+
where
|
46
|
+
});
|
47
|
+
return result;
|
48
|
+
}
|
49
|
+
|
50
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uL3NyYy91cGRhdGVWZXJzaW9uLnRzIl0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB0eXBlIHsgVHlwZVdpdGhWZXJzaW9uLCBVcGRhdGVWZXJzaW9uQXJncyB9IGZyb20gJ3BheWxvYWQvZGF0YWJhc2UnXG5pbXBvcnQgdHlwZSB7IFBheWxvYWRSZXF1ZXN0LCBTYW5pdGl6ZWRDb2xsZWN0aW9uQ29uZmlnLCBUeXBlV2l0aElEIH0gZnJvbSAncGF5bG9hZC90eXBlcydcblxuaW1wb3J0IHsgYnVpbGRWZXJzaW9uQ29sbGVjdGlvbkZpZWxkcyB9IGZyb20gJ3BheWxvYWQvdmVyc2lvbnMnXG5pbXBvcnQgdG9TbmFrZUNhc2UgZnJvbSAndG8tc25ha2UtY2FzZSdcblxuaW1wb3J0IHR5cGUgeyBQb3N0Z3Jlc0FkYXB0ZXIgfSBmcm9tICcuL3R5cGVzJ1xuXG5pbXBvcnQgYnVpbGRRdWVyeSBmcm9tICcuL3F1ZXJpZXMvYnVpbGRRdWVyeSdcbmltcG9ydCB7IHVwc2VydFJvdyB9IGZyb20gJy4vdXBzZXJ0Um93J1xuXG5leHBvcnQgYXN5bmMgZnVuY3Rpb24gdXBkYXRlVmVyc2lvbjxUIGV4dGVuZHMgVHlwZVdpdGhJRD4oXG4gIHRoaXM6IFBvc3RncmVzQWRhcHRlcixcbiAge1xuICAgIGlkLFxuICAgIGNvbGxlY3Rpb24sXG4gICAgbG9jYWxlLFxuICAgIHJlcSA9IHt9IGFzIFBheWxvYWRSZXF1ZXN0LFxuICAgIHZlcnNpb25EYXRhLFxuICAgIHdoZXJlOiB3aGVyZUFyZyxcbiAgfTogVXBkYXRlVmVyc2lvbkFyZ3M8VD4sXG4pIHtcbiAgY29uc3QgZGIgPSB0aGlzLnNlc3Npb25zW3JlcS50cmFuc2FjdGlvbklEXT8uZGIgfHwgdGhpcy5kYlxuICBjb25zdCBjb2xsZWN0aW9uQ29uZmlnOiBTYW5pdGl6ZWRDb2xsZWN0aW9uQ29uZmlnID0gdGhpcy5wYXlsb2FkLmNvbGxlY3Rpb25zW2NvbGxlY3Rpb25dLmNvbmZpZ1xuICBjb25zdCB3aGVyZVRvVXNlID0gd2hlcmVBcmcgfHwgeyBpZDogeyBlcXVhbHM6IGlkIH0gfVxuICBjb25zdCB0YWJsZU5hbWUgPSBgXyR7dG9TbmFrZUNhc2UoY29sbGVjdGlvbil9X3ZgXG4gIGNvbnN0IGZpZWxkcyA9IGJ1aWxkVmVyc2lvbkNvbGxlY3Rpb25GaWVsZHMoY29sbGVjdGlvbkNvbmZpZylcblxuICBjb25zdCB7IHdoZXJlIH0gPSBhd2FpdCBidWlsZFF1ZXJ5KHtcbiAgICBhZGFwdGVyOiB0aGlzLFxuICAgIGZpZWxkcyxcbiAgICBsb2NhbGUsXG4gICAgdGFibGVOYW1lLFxuICAgIHdoZXJlOiB3aGVyZVRvVXNlLFxuICB9KVxuXG4gIGNvbnN0IHJlc3VsdCA9IGF3YWl0IHVwc2VydFJvdzxUeXBlV2l0aFZlcnNpb248VD4+KHtcbiAgICBpZCxcbiAgICBhZGFwdGVyOiB0aGlzLFxuICAgIGRhdGE6IHZlcnNpb25EYXRhLFxuICAgIGRiLFxuICAgIGZpZWxkcyxcbiAgICBvcGVyYXRpb246ICd1cGRhdGUnLFxuICAgIHRhYmxlTmFtZSxcbiAgICB3aGVyZSxcbiAgfSlcblxuICByZXR1cm4gcmVzdWx0XG59XG4iXSwibmFtZXMiOlsidXBkYXRlVmVyc2lvbiIsImlkIiwiY29sbGVjdGlvbiIsImxvY2FsZSIsInJlcSIsInZlcnNpb25EYXRhIiwid2hlcmUiLCJ3aGVyZUFyZyIsImRiIiwic2Vzc2lvbnMiLCJ0cmFuc2FjdGlvbklEIiwiY29sbGVjdGlvbkNvbmZpZyIsInBheWxvYWQiLCJjb2xsZWN0aW9ucyIsImNvbmZpZyIsIndoZXJlVG9Vc2UiLCJlcXVhbHMiLCJ0YWJsZU5hbWUiLCJ0b1NuYWtlQ2FzZSIsImZpZWxkcyIsImJ1aWxkVmVyc2lvbkNvbGxlY3Rpb25GaWVsZHMiLCJidWlsZFF1ZXJ5IiwiYWRhcHRlciIsInJlc3VsdCIsInVwc2VydFJvdyIsImRhdGEiLCJvcGVyYXRpb24iXSwibWFwcGluZ3MiOiI7Ozs7K0JBV3NCQTs7O2VBQUFBOzs7MEJBUnVCO29FQUNyQjttRUFJRDsyQkFDRzs7Ozs7O0FBRW5CLGVBQWVBLGNBRXBCLEVBQ0VDLEVBQUUsRUFDRkMsVUFBVSxFQUNWQyxNQUFNLEVBQ05DLE1BQU0sQ0FBQyxDQUFtQixFQUMxQkMsV0FBVyxFQUNYQyxPQUFPQyxRQUFRLEVBQ007SUFFdkIsTUFBTUMsS0FBSyxJQUFJLENBQUNDLFFBQVEsQ0FBQ0wsSUFBSU0sYUFBYSxDQUFDLEVBQUVGLE1BQU0sSUFBSSxDQUFDQSxFQUFFO0lBQzFELE1BQU1HLG1CQUE4QyxJQUFJLENBQUNDLE9BQU8sQ0FBQ0MsV0FBVyxDQUFDWCxXQUFXLENBQUNZLE1BQU07SUFDL0YsTUFBTUMsYUFBYVIsWUFBWTtRQUFFTixJQUFJO1lBQUVlLFFBQVFmO1FBQUc7SUFBRTtJQUNwRCxNQUFNZ0IsWUFBWSxDQUFDLENBQUMsRUFBRUMsSUFBQUEsb0JBQVcsRUFBQ2hCLFlBQVksRUFBRSxDQUFDO0lBQ2pELE1BQU1pQixTQUFTQyxJQUFBQSxzQ0FBNEIsRUFBQ1Q7SUFFNUMsTUFBTSxFQUFFTCxLQUFLLEVBQUUsR0FBRyxNQUFNZSxJQUFBQSxtQkFBVSxFQUFDO1FBQ2pDQyxTQUFTLElBQUk7UUFDYkg7UUFDQWhCO1FBQ0FjO1FBQ0FYLE9BQU9TO0lBQ1Q7SUFFQSxNQUFNUSxTQUFTLE1BQU1DLElBQUFBLG9CQUFTLEVBQXFCO1FBQ2pEdkI7UUFDQXFCLFNBQVMsSUFBSTtRQUNiRyxNQUFNcEI7UUFDTkc7UUFDQVc7UUFDQU8sV0FBVztRQUNYVDtRQUNBWDtJQUNGO0lBRUEsT0FBT2lCO0FBQ1QifQ==
|
@@ -0,0 +1,20 @@
|
|
1
|
+
"use strict";
|
2
|
+
Object.defineProperty(exports, "__esModule", {
|
3
|
+
value: true
|
4
|
+
});
|
5
|
+
Object.defineProperty(exports, "deleteExistingArrayRows", {
|
6
|
+
enumerable: true,
|
7
|
+
get: function() {
|
8
|
+
return deleteExistingArrayRows;
|
9
|
+
}
|
10
|
+
});
|
11
|
+
const _drizzleorm = require("drizzle-orm");
|
12
|
+
const deleteExistingArrayRows = async ({ adapter, db, parentID, tableName })=>{
|
13
|
+
const table = adapter.tables[tableName];
|
14
|
+
const whereConstraints = [
|
15
|
+
(0, _drizzleorm.eq)(table._parentID, parentID)
|
16
|
+
];
|
17
|
+
await db.delete(table).where((0, _drizzleorm.and)(...whereConstraints));
|
18
|
+
};
|
19
|
+
|
20
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy91cHNlcnRSb3cvZGVsZXRlRXhpc3RpbmdBcnJheVJvd3MudHMiXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgYW5kLCBlcSB9IGZyb20gJ2RyaXp6bGUtb3JtJ1xuXG5pbXBvcnQgdHlwZSB7IERyaXp6bGVEQiwgUG9zdGdyZXNBZGFwdGVyIH0gZnJvbSAnLi4vdHlwZXMnXG5cbnR5cGUgQXJncyA9IHtcbiAgYWRhcHRlcjogUG9zdGdyZXNBZGFwdGVyXG4gIGRiOiBEcml6emxlREJcbiAgcGFyZW50SUQ6IHVua25vd25cbiAgdGFibGVOYW1lOiBzdHJpbmdcbn1cblxuZXhwb3J0IGNvbnN0IGRlbGV0ZUV4aXN0aW5nQXJyYXlSb3dzID0gYXN5bmMgKHtcbiAgYWRhcHRlcixcbiAgZGIsXG4gIHBhcmVudElELFxuICB0YWJsZU5hbWUsXG59OiBBcmdzKTogUHJvbWlzZTx2b2lkPiA9PiB7XG4gIGNvbnN0IHRhYmxlID0gYWRhcHRlci50YWJsZXNbdGFibGVOYW1lXVxuXG4gIGNvbnN0IHdoZXJlQ29uc3RyYWludHMgPSBbZXEodGFibGUuX3BhcmVudElELCBwYXJlbnRJRCldXG5cbiAgYXdhaXQgZGIuZGVsZXRlKHRhYmxlKS53aGVyZShhbmQoLi4ud2hlcmVDb25zdHJhaW50cykpXG59XG4iXSwibmFtZXMiOlsiZGVsZXRlRXhpc3RpbmdBcnJheVJvd3MiLCJhZGFwdGVyIiwiZGIiLCJwYXJlbnRJRCIsInRhYmxlTmFtZSIsInRhYmxlIiwidGFibGVzIiwid2hlcmVDb25zdHJhaW50cyIsImVxIiwiX3BhcmVudElEIiwiZGVsZXRlIiwid2hlcmUiLCJhbmQiXSwibWFwcGluZ3MiOiI7Ozs7K0JBV2FBOzs7ZUFBQUE7Ozs0QkFYVztBQVdqQixNQUFNQSwwQkFBMEIsT0FBTyxFQUM1Q0MsT0FBTyxFQUNQQyxFQUFFLEVBQ0ZDLFFBQVEsRUFDUkMsU0FBUyxFQUNKO0lBQ0wsTUFBTUMsUUFBUUosUUFBUUssTUFBTSxDQUFDRixVQUFVO0lBRXZDLE1BQU1HLG1CQUFtQjtRQUFDQyxJQUFBQSxjQUFFLEVBQUNILE1BQU1JLFNBQVMsRUFBRU47S0FBVTtJQUV4RCxNQUFNRCxHQUFHUSxNQUFNLENBQUNMLE9BQU9NLEtBQUssQ0FBQ0MsSUFBQUEsZUFBRyxLQUFJTDtBQUN0QyJ9
|
@@ -0,0 +1,43 @@
|
|
1
|
+
"use strict";
|
2
|
+
Object.defineProperty(exports, "__esModule", {
|
3
|
+
value: true
|
4
|
+
});
|
5
|
+
Object.defineProperty(exports, "deleteExistingRowsByPath", {
|
6
|
+
enumerable: true,
|
7
|
+
get: function() {
|
8
|
+
return deleteExistingRowsByPath;
|
9
|
+
}
|
10
|
+
});
|
11
|
+
const _drizzleorm = require("drizzle-orm");
|
12
|
+
const deleteExistingRowsByPath = async ({ adapter, db, localeColumnName = '_locale', parentColumnName = '_parentID', parentID, pathColumnName = '_path', rows, tableName })=>{
|
13
|
+
const localizedPathsToDelete = new Set();
|
14
|
+
const pathsToDelete = new Set();
|
15
|
+
const table = adapter.tables[tableName];
|
16
|
+
rows.forEach((row)=>{
|
17
|
+
const path = row[pathColumnName];
|
18
|
+
const localeData = row[localeColumnName];
|
19
|
+
if (typeof path === 'string') {
|
20
|
+
if (typeof localeData === 'string') {
|
21
|
+
localizedPathsToDelete.add(path);
|
22
|
+
} else {
|
23
|
+
pathsToDelete.add(path);
|
24
|
+
}
|
25
|
+
}
|
26
|
+
});
|
27
|
+
if (localizedPathsToDelete.size > 0) {
|
28
|
+
const whereConstraints = [
|
29
|
+
(0, _drizzleorm.eq)(table[parentColumnName], parentID)
|
30
|
+
];
|
31
|
+
if (pathColumnName) whereConstraints.push((0, _drizzleorm.inArray)(table[pathColumnName], Array.from(localizedPathsToDelete)));
|
32
|
+
await db.delete(table).where((0, _drizzleorm.and)(...whereConstraints));
|
33
|
+
}
|
34
|
+
if (pathsToDelete.size > 0) {
|
35
|
+
const whereConstraints = [
|
36
|
+
(0, _drizzleorm.eq)(table[parentColumnName], parentID)
|
37
|
+
];
|
38
|
+
if (pathColumnName) whereConstraints.push((0, _drizzleorm.inArray)(table[pathColumnName], Array.from(pathsToDelete)));
|
39
|
+
await db.delete(table).where((0, _drizzleorm.and)(...whereConstraints));
|
40
|
+
}
|
41
|
+
};
|
42
|
+
|
43
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy91cHNlcnRSb3cvZGVsZXRlRXhpc3RpbmdSb3dzQnlQYXRoLnRzIl0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IGFuZCwgZXEsIGluQXJyYXkgfSBmcm9tICdkcml6emxlLW9ybSdcblxuaW1wb3J0IHR5cGUgeyBEcml6emxlREIsIFBvc3RncmVzQWRhcHRlciB9IGZyb20gJy4uL3R5cGVzJ1xuXG50eXBlIEFyZ3MgPSB7XG4gIGFkYXB0ZXI6IFBvc3RncmVzQWRhcHRlclxuICBkYjogRHJpenpsZURCXG4gIGxvY2FsZUNvbHVtbk5hbWU/OiBzdHJpbmdcbiAgcGFyZW50Q29sdW1uTmFtZT86IHN0cmluZ1xuICBwYXJlbnRJRDogdW5rbm93blxuICBwYXRoQ29sdW1uTmFtZT86IHN0cmluZ1xuICByb3dzOiBSZWNvcmQ8c3RyaW5nLCB1bmtub3duPltdXG4gIHRhYmxlTmFtZTogc3RyaW5nXG59XG5cbmV4cG9ydCBjb25zdCBkZWxldGVFeGlzdGluZ1Jvd3NCeVBhdGggPSBhc3luYyAoe1xuICBhZGFwdGVyLFxuICBkYixcbiAgbG9jYWxlQ29sdW1uTmFtZSA9ICdfbG9jYWxlJyxcbiAgcGFyZW50Q29sdW1uTmFtZSA9ICdfcGFyZW50SUQnLFxuICBwYXJlbnRJRCxcbiAgcGF0aENvbHVtbk5hbWUgPSAnX3BhdGgnLFxuICByb3dzLFxuICB0YWJsZU5hbWUsXG59OiBBcmdzKTogUHJvbWlzZTx2b2lkPiA9PiB7XG4gIGNvbnN0IGxvY2FsaXplZFBhdGhzVG9EZWxldGUgPSBuZXcgU2V0PHN0cmluZz4oKVxuICBjb25zdCBwYXRoc1RvRGVsZXRlID0gbmV3IFNldDxzdHJpbmc+KClcbiAgY29uc3QgdGFibGUgPSBhZGFwdGVyLnRhYmxlc1t0YWJsZU5hbWVdXG5cbiAgcm93cy5mb3JFYWNoKChyb3cpID0+IHtcbiAgICBjb25zdCBwYXRoID0gcm93W3BhdGhDb2x1bW5OYW1lXVxuICAgIGNvbnN0IGxvY2FsZURhdGEgPSByb3dbbG9jYWxlQ29sdW1uTmFtZV1cbiAgICBpZiAodHlwZW9mIHBhdGggPT09ICdzdHJpbmcnKSB7XG4gICAgICBpZiAodHlwZW9mIGxvY2FsZURhdGEgPT09ICdzdHJpbmcnKSB7XG4gICAgICAgIGxvY2FsaXplZFBhdGhzVG9EZWxldGUuYWRkKHBhdGgpXG4gICAgICB9IGVsc2Uge1xuICAgICAgICBwYXRoc1RvRGVsZXRlLmFkZChwYXRoKVxuICAgICAgfVxuICAgIH1cbiAgfSlcblxuICBpZiAobG9jYWxpemVkUGF0aHNUb0RlbGV0ZS5zaXplID4gMCkge1xuICAgIGNvbnN0IHdoZXJlQ29uc3RyYWludHMgPSBbZXEodGFibGVbcGFyZW50Q29sdW1uTmFtZV0sIHBhcmVudElEKV1cblxuICAgIGlmIChwYXRoQ29sdW1uTmFtZSlcbiAgICAgIHdoZXJlQ29uc3RyYWludHMucHVzaChpbkFycmF5KHRhYmxlW3BhdGhDb2x1bW5OYW1lXSwgQXJyYXkuZnJvbShsb2NhbGl6ZWRQYXRoc1RvRGVsZXRlKSkpXG5cbiAgICBhd2FpdCBkYi5kZWxldGUodGFibGUpLndoZXJlKGFuZCguLi53aGVyZUNvbnN0cmFpbnRzKSlcbiAgfVxuXG4gIGlmIChwYXRoc1RvRGVsZXRlLnNpemUgPiAwKSB7XG4gICAgY29uc3Qgd2hlcmVDb25zdHJhaW50cyA9IFtlcSh0YWJsZVtwYXJlbnRDb2x1bW5OYW1lXSwgcGFyZW50SUQpXVxuXG4gICAgaWYgKHBhdGhDb2x1bW5OYW1lKVxuICAgICAgd2hlcmVDb25zdHJhaW50cy5wdXNoKGluQXJyYXkodGFibGVbcGF0aENvbHVtbk5hbWVdLCBBcnJheS5mcm9tKHBhdGhzVG9EZWxldGUpKSlcblxuICAgIGF3YWl0IGRiLmRlbGV0ZSh0YWJsZSkud2hlcmUoYW5kKC4uLndoZXJlQ29uc3RyYWludHMpKVxuICB9XG59XG4iXSwibmFtZXMiOlsiZGVsZXRlRXhpc3RpbmdSb3dzQnlQYXRoIiwiYWRhcHRlciIsImRiIiwibG9jYWxlQ29sdW1uTmFtZSIsInBhcmVudENvbHVtbk5hbWUiLCJwYXJlbnRJRCIsInBhdGhDb2x1bW5OYW1lIiwicm93cyIsInRhYmxlTmFtZSIsImxvY2FsaXplZFBhdGhzVG9EZWxldGUiLCJTZXQiLCJwYXRoc1RvRGVsZXRlIiwidGFibGUiLCJ0YWJsZXMiLCJmb3JFYWNoIiwicm93IiwicGF0aCIsImxvY2FsZURhdGEiLCJhZGQiLCJzaXplIiwid2hlcmVDb25zdHJhaW50cyIsImVxIiwicHVzaCIsImluQXJyYXkiLCJBcnJheSIsImZyb20iLCJkZWxldGUiLCJ3aGVyZSIsImFuZCJdLCJtYXBwaW5ncyI6Ijs7OzsrQkFlYUE7OztlQUFBQTs7OzRCQWZvQjtBQWUxQixNQUFNQSwyQkFBMkIsT0FBTyxFQUM3Q0MsT0FBTyxFQUNQQyxFQUFFLEVBQ0ZDLG1CQUFtQixTQUFTLEVBQzVCQyxtQkFBbUIsV0FBVyxFQUM5QkMsUUFBUSxFQUNSQyxpQkFBaUIsT0FBTyxFQUN4QkMsSUFBSSxFQUNKQyxTQUFTLEVBQ0o7SUFDTCxNQUFNQyx5QkFBeUIsSUFBSUM7SUFDbkMsTUFBTUMsZ0JBQWdCLElBQUlEO0lBQzFCLE1BQU1FLFFBQVFYLFFBQVFZLE1BQU0sQ0FBQ0wsVUFBVTtJQUV2Q0QsS0FBS08sT0FBTyxDQUFDLENBQUNDO1FBQ1osTUFBTUMsT0FBT0QsR0FBRyxDQUFDVCxlQUFlO1FBQ2hDLE1BQU1XLGFBQWFGLEdBQUcsQ0FBQ1osaUJBQWlCO1FBQ3hDLElBQUksT0FBT2EsU0FBUyxVQUFVO1lBQzVCLElBQUksT0FBT0MsZUFBZSxVQUFVO2dCQUNsQ1IsdUJBQXVCUyxHQUFHLENBQUNGO1lBQzdCLE9BQU87Z0JBQ0xMLGNBQWNPLEdBQUcsQ0FBQ0Y7WUFDcEI7UUFDRjtJQUNGO0lBRUEsSUFBSVAsdUJBQXVCVSxJQUFJLEdBQUcsR0FBRztRQUNuQyxNQUFNQyxtQkFBbUI7WUFBQ0MsSUFBQUEsY0FBRSxFQUFDVCxLQUFLLENBQUNSLGlCQUFpQixFQUFFQztTQUFVO1FBRWhFLElBQUlDLGdCQUNGYyxpQkFBaUJFLElBQUksQ0FBQ0MsSUFBQUEsbUJBQU8sRUFBQ1gsS0FBSyxDQUFDTixlQUFlLEVBQUVrQixNQUFNQyxJQUFJLENBQUNoQjtRQUVsRSxNQUFNUCxHQUFHd0IsTUFBTSxDQUFDZCxPQUFPZSxLQUFLLENBQUNDLElBQUFBLGVBQUcsS0FBSVI7SUFDdEM7SUFFQSxJQUFJVCxjQUFjUSxJQUFJLEdBQUcsR0FBRztRQUMxQixNQUFNQyxtQkFBbUI7WUFBQ0MsSUFBQUEsY0FBRSxFQUFDVCxLQUFLLENBQUNSLGlCQUFpQixFQUFFQztTQUFVO1FBRWhFLElBQUlDLGdCQUNGYyxpQkFBaUJFLElBQUksQ0FBQ0MsSUFBQUEsbUJBQU8sRUFBQ1gsS0FBSyxDQUFDTixlQUFlLEVBQUVrQixNQUFNQyxJQUFJLENBQUNkO1FBRWxFLE1BQU1ULEdBQUd3QixNQUFNLENBQUNkLE9BQU9lLEtBQUssQ0FBQ0MsSUFBQUEsZUFBRyxLQUFJUjtJQUN0QztBQUNGIn0=
|
@@ -0,0 +1,243 @@
|
|
1
|
+
/* eslint-disable no-param-reassign */ "use strict";
|
2
|
+
Object.defineProperty(exports, "__esModule", {
|
3
|
+
value: true
|
4
|
+
});
|
5
|
+
Object.defineProperty(exports, "upsertRow", {
|
6
|
+
enumerable: true,
|
7
|
+
get: function() {
|
8
|
+
return upsertRow;
|
9
|
+
}
|
10
|
+
});
|
11
|
+
const _drizzleorm = require("drizzle-orm");
|
12
|
+
const _buildFindManyArgs = require("../find/buildFindManyArgs");
|
13
|
+
const _read = require("../transform/read");
|
14
|
+
const _write = require("../transform/write");
|
15
|
+
const _deleteExistingArrayRows = require("./deleteExistingArrayRows");
|
16
|
+
const _deleteExistingRowsByPath = require("./deleteExistingRowsByPath");
|
17
|
+
const _insertArrays = require("./insertArrays");
|
18
|
+
const upsertRow = async ({ id, adapter, data, db, fields, operation, path = '', tableName, upsertTarget, where })=>{
|
19
|
+
// Split out the incoming data into the corresponding:
|
20
|
+
// base row, locales, relationships, blocks, and arrays
|
21
|
+
const rowToInsert = (0, _write.transformForWrite)({
|
22
|
+
data,
|
23
|
+
fields,
|
24
|
+
path,
|
25
|
+
tableName
|
26
|
+
});
|
27
|
+
// First, we insert the main row
|
28
|
+
let insertedRow;
|
29
|
+
if (operation === 'update') {
|
30
|
+
const target = upsertTarget || adapter.tables[tableName].id;
|
31
|
+
if (id) {
|
32
|
+
rowToInsert.row.id = id;
|
33
|
+
[insertedRow] = await db.insert(adapter.tables[tableName]).values(rowToInsert.row).onConflictDoUpdate({
|
34
|
+
set: rowToInsert.row,
|
35
|
+
target
|
36
|
+
}).returning();
|
37
|
+
} else {
|
38
|
+
[insertedRow] = await db.insert(adapter.tables[tableName]).values(rowToInsert.row).onConflictDoUpdate({
|
39
|
+
set: rowToInsert.row,
|
40
|
+
target,
|
41
|
+
where
|
42
|
+
}).returning();
|
43
|
+
}
|
44
|
+
} else {
|
45
|
+
[insertedRow] = await db.insert(adapter.tables[tableName]).values(rowToInsert.row).returning();
|
46
|
+
}
|
47
|
+
const localesToInsert = [];
|
48
|
+
const relationsToInsert = [];
|
49
|
+
const numbersToInsert = [];
|
50
|
+
const blocksToInsert = {};
|
51
|
+
const selectsToInsert = {};
|
52
|
+
// If there are locale rows with data, add the parent and locale to each
|
53
|
+
if (Object.keys(rowToInsert.locales).length > 0) {
|
54
|
+
Object.entries(rowToInsert.locales).forEach(([locale, localeRow])=>{
|
55
|
+
localeRow._parentID = insertedRow.id;
|
56
|
+
localeRow._locale = locale;
|
57
|
+
localesToInsert.push(localeRow);
|
58
|
+
});
|
59
|
+
}
|
60
|
+
// If there are relationships, add parent to each
|
61
|
+
if (rowToInsert.relationships.length > 0) {
|
62
|
+
rowToInsert.relationships.forEach((relation)=>{
|
63
|
+
relation.parent = insertedRow.id;
|
64
|
+
relationsToInsert.push(relation);
|
65
|
+
});
|
66
|
+
}
|
67
|
+
// If there are numbers, add parent to each
|
68
|
+
if (rowToInsert.numbers.length > 0) {
|
69
|
+
rowToInsert.numbers.forEach((numberRow)=>{
|
70
|
+
numberRow.parent = insertedRow.id;
|
71
|
+
numbersToInsert.push(numberRow);
|
72
|
+
});
|
73
|
+
}
|
74
|
+
// If there are selects, add parent to each, and then
|
75
|
+
// store by table name and rows
|
76
|
+
if (Object.keys(rowToInsert.selects).length > 0) {
|
77
|
+
Object.entries(rowToInsert.selects).forEach(([selectTableName, selectRows])=>{
|
78
|
+
selectRows.forEach((row)=>{
|
79
|
+
row.parent = insertedRow.id;
|
80
|
+
if (!selectsToInsert[selectTableName]) selectsToInsert[selectTableName] = [];
|
81
|
+
selectsToInsert[selectTableName].push(row);
|
82
|
+
});
|
83
|
+
});
|
84
|
+
}
|
85
|
+
// If there are blocks, add parent to each, and then
|
86
|
+
// store by table name and rows
|
87
|
+
Object.keys(rowToInsert.blocks).forEach((blockName)=>{
|
88
|
+
rowToInsert.blocks[blockName].forEach((blockRow)=>{
|
89
|
+
blockRow.row._parentID = insertedRow.id;
|
90
|
+
if (!blocksToInsert[blockName]) blocksToInsert[blockName] = [];
|
91
|
+
blocksToInsert[blockName].push(blockRow);
|
92
|
+
});
|
93
|
+
});
|
94
|
+
// //////////////////////////////////
|
95
|
+
// INSERT LOCALES
|
96
|
+
// //////////////////////////////////
|
97
|
+
if (localesToInsert.length > 0) {
|
98
|
+
const localeTable = adapter.tables[`${tableName}_locales`];
|
99
|
+
if (operation === 'update') {
|
100
|
+
await db.delete(localeTable).where((0, _drizzleorm.eq)(localeTable._parentID, insertedRow.id));
|
101
|
+
}
|
102
|
+
await db.insert(localeTable).values(localesToInsert);
|
103
|
+
}
|
104
|
+
// //////////////////////////////////
|
105
|
+
// INSERT RELATIONSHIPS
|
106
|
+
// //////////////////////////////////
|
107
|
+
const relationshipsTableName = `${tableName}_relationships`;
|
108
|
+
if (operation === 'update') {
|
109
|
+
await (0, _deleteExistingRowsByPath.deleteExistingRowsByPath)({
|
110
|
+
adapter,
|
111
|
+
db,
|
112
|
+
localeColumnName: 'locale',
|
113
|
+
parentColumnName: 'parent',
|
114
|
+
parentID: insertedRow.id,
|
115
|
+
pathColumnName: 'path',
|
116
|
+
rows: [
|
117
|
+
...relationsToInsert,
|
118
|
+
...rowToInsert.relationshipsToDelete
|
119
|
+
],
|
120
|
+
tableName: relationshipsTableName
|
121
|
+
});
|
122
|
+
}
|
123
|
+
if (relationsToInsert.length > 0) {
|
124
|
+
await db.insert(adapter.tables[relationshipsTableName]).values(relationsToInsert);
|
125
|
+
}
|
126
|
+
// //////////////////////////////////
|
127
|
+
// INSERT hasMany NUMBERS
|
128
|
+
// //////////////////////////////////
|
129
|
+
const numbersTableName = `${tableName}_numbers`;
|
130
|
+
if (operation === 'update') {
|
131
|
+
await (0, _deleteExistingRowsByPath.deleteExistingRowsByPath)({
|
132
|
+
adapter,
|
133
|
+
db,
|
134
|
+
localeColumnName: 'locale',
|
135
|
+
parentColumnName: 'parent',
|
136
|
+
parentID: insertedRow.id,
|
137
|
+
pathColumnName: 'path',
|
138
|
+
rows: numbersToInsert,
|
139
|
+
tableName: numbersTableName
|
140
|
+
});
|
141
|
+
}
|
142
|
+
if (numbersToInsert.length > 0) {
|
143
|
+
await db.insert(adapter.tables[numbersTableName]).values(numbersToInsert).returning();
|
144
|
+
}
|
145
|
+
// //////////////////////////////////
|
146
|
+
// INSERT BLOCKS
|
147
|
+
// //////////////////////////////////
|
148
|
+
const insertedBlockRows = {};
|
149
|
+
for (const [blockName, blockRows] of Object.entries(blocksToInsert)){
|
150
|
+
if (operation === 'update') {
|
151
|
+
await (0, _deleteExistingRowsByPath.deleteExistingRowsByPath)({
|
152
|
+
adapter,
|
153
|
+
db,
|
154
|
+
parentID: insertedRow.id,
|
155
|
+
pathColumnName: '_path',
|
156
|
+
rows: blockRows.map(({ row })=>row),
|
157
|
+
tableName: `${tableName}_blocks_${blockName}`
|
158
|
+
});
|
159
|
+
}
|
160
|
+
insertedBlockRows[blockName] = await db.insert(adapter.tables[`${tableName}_blocks_${blockName}`]).values(blockRows.map(({ row })=>row)).returning();
|
161
|
+
insertedBlockRows[blockName].forEach((row, i)=>{
|
162
|
+
blockRows[i].row = row;
|
163
|
+
});
|
164
|
+
const blockLocaleIndexMap = [];
|
165
|
+
const blockLocaleRowsToInsert = blockRows.reduce((acc, blockRow, i)=>{
|
166
|
+
if (Object.entries(blockRow.locales).length > 0) {
|
167
|
+
Object.entries(blockRow.locales).forEach(([blockLocale, blockLocaleData])=>{
|
168
|
+
if (Object.keys(blockLocaleData).length > 0) {
|
169
|
+
blockLocaleData._parentID = blockRow.row.id;
|
170
|
+
blockLocaleData._locale = blockLocale;
|
171
|
+
acc.push(blockLocaleData);
|
172
|
+
blockLocaleIndexMap.push(i);
|
173
|
+
}
|
174
|
+
});
|
175
|
+
}
|
176
|
+
return acc;
|
177
|
+
}, []);
|
178
|
+
if (blockLocaleRowsToInsert.length > 0) {
|
179
|
+
await db.insert(adapter.tables[`${tableName}_blocks_${blockName}_locales`]).values(blockLocaleRowsToInsert).returning();
|
180
|
+
}
|
181
|
+
await (0, _insertArrays.insertArrays)({
|
182
|
+
adapter,
|
183
|
+
arrays: blockRows.map(({ arrays })=>arrays),
|
184
|
+
db,
|
185
|
+
parentRows: insertedBlockRows[blockName]
|
186
|
+
});
|
187
|
+
}
|
188
|
+
// //////////////////////////////////
|
189
|
+
// INSERT ARRAYS RECURSIVELY
|
190
|
+
// //////////////////////////////////
|
191
|
+
if (operation === 'update') {
|
192
|
+
for (const arrayTableName of Object.keys(rowToInsert.arrays)){
|
193
|
+
await (0, _deleteExistingArrayRows.deleteExistingArrayRows)({
|
194
|
+
adapter,
|
195
|
+
db,
|
196
|
+
parentID: insertedRow.id,
|
197
|
+
tableName: arrayTableName
|
198
|
+
});
|
199
|
+
}
|
200
|
+
}
|
201
|
+
await (0, _insertArrays.insertArrays)({
|
202
|
+
adapter,
|
203
|
+
arrays: [
|
204
|
+
rowToInsert.arrays
|
205
|
+
],
|
206
|
+
db,
|
207
|
+
parentRows: [
|
208
|
+
insertedRow
|
209
|
+
]
|
210
|
+
});
|
211
|
+
// //////////////////////////////////
|
212
|
+
// INSERT hasMany SELECTS
|
213
|
+
// //////////////////////////////////
|
214
|
+
for (const [selectTableName, tableRows] of Object.entries(selectsToInsert)){
|
215
|
+
const selectTable = adapter.tables[selectTableName];
|
216
|
+
if (operation === 'update') {
|
217
|
+
await db.delete(selectTable).where((0, _drizzleorm.eq)(selectTable.parent, insertedRow.id));
|
218
|
+
}
|
219
|
+
await db.insert(selectTable).values(tableRows).returning();
|
220
|
+
}
|
221
|
+
// //////////////////////////////////
|
222
|
+
// RETRIEVE NEWLY UPDATED ROW
|
223
|
+
// //////////////////////////////////
|
224
|
+
const findManyArgs = (0, _buildFindManyArgs.buildFindManyArgs)({
|
225
|
+
adapter,
|
226
|
+
depth: 0,
|
227
|
+
fields,
|
228
|
+
tableName
|
229
|
+
});
|
230
|
+
findManyArgs.where = (0, _drizzleorm.eq)(adapter.tables[tableName].id, insertedRow.id);
|
231
|
+
const doc = await db.query[tableName].findFirst(findManyArgs);
|
232
|
+
// //////////////////////////////////
|
233
|
+
// TRANSFORM DATA
|
234
|
+
// //////////////////////////////////
|
235
|
+
const result = (0, _read.transform)({
|
236
|
+
config: adapter.payload.config,
|
237
|
+
data: doc,
|
238
|
+
fields
|
239
|
+
});
|
240
|
+
return result;
|
241
|
+
};
|
242
|
+
|
243
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../src/upsertRow/index.ts"],"sourcesContent":["/* eslint-disable no-param-reassign */\nimport type { TypeWithID } from 'payload/types'\n\nimport { eq } from 'drizzle-orm'\n\nimport type { BlockRowToInsert } from '../transform/write/types'\nimport type { Args } from './types'\n\nimport { buildFindManyArgs } from '../find/buildFindManyArgs'\nimport { transform } from '../transform/read'\nimport { transformForWrite } from '../transform/write'\nimport { deleteExistingArrayRows } from './deleteExistingArrayRows'\nimport { deleteExistingRowsByPath } from './deleteExistingRowsByPath'\nimport { insertArrays } from './insertArrays'\n\nexport const upsertRow = async <T extends TypeWithID>({\n  id,\n  adapter,\n  data,\n  db,\n  fields,\n  operation,\n  path = '',\n  tableName,\n  upsertTarget,\n  where,\n}: Args): Promise<T> => {\n  // Split out the incoming data into the corresponding:\n  // base row, locales, relationships, blocks, and arrays\n  const rowToInsert = transformForWrite({\n    data,\n    fields,\n    path,\n    tableName,\n  })\n\n  // First, we insert the main row\n  let insertedRow: Record<string, unknown>\n\n  if (operation === 'update') {\n    const target = upsertTarget || adapter.tables[tableName].id\n\n    if (id) {\n      rowToInsert.row.id = id\n      ;[insertedRow] = await db\n        .insert(adapter.tables[tableName])\n        .values(rowToInsert.row)\n        .onConflictDoUpdate({ set: rowToInsert.row, target })\n        .returning()\n    } else {\n      ;[insertedRow] = await db\n        .insert(adapter.tables[tableName])\n        .values(rowToInsert.row)\n        .onConflictDoUpdate({ set: rowToInsert.row, target, where })\n        .returning()\n    }\n  } else {\n    ;[insertedRow] = await db.insert(adapter.tables[tableName]).values(rowToInsert.row).returning()\n  }\n\n  const localesToInsert: Record<string, unknown>[] = []\n  const relationsToInsert: Record<string, unknown>[] = []\n  const numbersToInsert: Record<string, unknown>[] = []\n  const blocksToInsert: { [blockType: string]: BlockRowToInsert[] } = {}\n  const selectsToInsert: { [selectTableName: string]: Record<string, unknown>[] } = {}\n\n  // If there are locale rows with data, add the parent and locale to each\n  if (Object.keys(rowToInsert.locales).length > 0) {\n    Object.entries(rowToInsert.locales).forEach(([locale, localeRow]) => {\n      localeRow._parentID = insertedRow.id\n      localeRow._locale = locale\n      localesToInsert.push(localeRow)\n    })\n  }\n\n  // If there are relationships, add parent to each\n  if (rowToInsert.relationships.length > 0) {\n    rowToInsert.relationships.forEach((relation) => {\n      relation.parent = insertedRow.id\n      relationsToInsert.push(relation)\n    })\n  }\n\n  // If there are numbers, add parent to each\n  if (rowToInsert.numbers.length > 0) {\n    rowToInsert.numbers.forEach((numberRow) => {\n      numberRow.parent = insertedRow.id\n      numbersToInsert.push(numberRow)\n    })\n  }\n\n  // If there are selects, add parent to each, and then\n  // store by table name and rows\n  if (Object.keys(rowToInsert.selects).length > 0) {\n    Object.entries(rowToInsert.selects).forEach(([selectTableName, selectRows]) => {\n      selectRows.forEach((row) => {\n        row.parent = insertedRow.id\n        if (!selectsToInsert[selectTableName]) selectsToInsert[selectTableName] = []\n        selectsToInsert[selectTableName].push(row)\n      })\n    })\n  }\n\n  // If there are blocks, add parent to each, and then\n  // store by table name and rows\n  Object.keys(rowToInsert.blocks).forEach((blockName) => {\n    rowToInsert.blocks[blockName].forEach((blockRow) => {\n      blockRow.row._parentID = insertedRow.id\n      if (!blocksToInsert[blockName]) blocksToInsert[blockName] = []\n      blocksToInsert[blockName].push(blockRow)\n    })\n  })\n\n  // //////////////////////////////////\n  // INSERT LOCALES\n  // //////////////////////////////////\n\n  if (localesToInsert.length > 0) {\n    const localeTable = adapter.tables[`${tableName}_locales`]\n\n    if (operation === 'update') {\n      await db.delete(localeTable).where(eq(localeTable._parentID, insertedRow.id))\n    }\n\n    await db.insert(localeTable).values(localesToInsert)\n  }\n\n  // //////////////////////////////////\n  // INSERT RELATIONSHIPS\n  // //////////////////////////////////\n\n  const relationshipsTableName = `${tableName}_relationships`\n\n  if (operation === 'update') {\n    await deleteExistingRowsByPath({\n      adapter,\n      db,\n      localeColumnName: 'locale',\n      parentColumnName: 'parent',\n      parentID: insertedRow.id,\n      pathColumnName: 'path',\n      rows: [...relationsToInsert, ...rowToInsert.relationshipsToDelete],\n      tableName: relationshipsTableName,\n    })\n  }\n\n  if (relationsToInsert.length > 0) {\n    await db.insert(adapter.tables[relationshipsTableName]).values(relationsToInsert)\n  }\n\n  // //////////////////////////////////\n  // INSERT hasMany NUMBERS\n  // //////////////////////////////////\n\n  const numbersTableName = `${tableName}_numbers`\n\n  if (operation === 'update') {\n    await deleteExistingRowsByPath({\n      adapter,\n      db,\n      localeColumnName: 'locale',\n      parentColumnName: 'parent',\n      parentID: insertedRow.id,\n      pathColumnName: 'path',\n      rows: numbersToInsert,\n      tableName: numbersTableName,\n    })\n  }\n\n  if (numbersToInsert.length > 0) {\n    await db.insert(adapter.tables[numbersTableName]).values(numbersToInsert).returning()\n  }\n\n  // //////////////////////////////////\n  // INSERT BLOCKS\n  // //////////////////////////////////\n\n  const insertedBlockRows: Record<string, Record<string, unknown>[]> = {}\n\n  for (const [blockName, blockRows] of Object.entries(blocksToInsert)) {\n    if (operation === 'update') {\n      await deleteExistingRowsByPath({\n        adapter,\n        db,\n        parentID: insertedRow.id,\n        pathColumnName: '_path',\n        rows: blockRows.map(({ row }) => row),\n        tableName: `${tableName}_blocks_${blockName}`,\n      })\n    }\n\n    insertedBlockRows[blockName] = await db\n      .insert(adapter.tables[`${tableName}_blocks_${blockName}`])\n      .values(blockRows.map(({ row }) => row))\n      .returning()\n\n    insertedBlockRows[blockName].forEach((row, i) => {\n      blockRows[i].row = row\n    })\n\n    const blockLocaleIndexMap: number[] = []\n\n    const blockLocaleRowsToInsert = blockRows.reduce((acc, blockRow, i) => {\n      if (Object.entries(blockRow.locales).length > 0) {\n        Object.entries(blockRow.locales).forEach(([blockLocale, blockLocaleData]) => {\n          if (Object.keys(blockLocaleData).length > 0) {\n            blockLocaleData._parentID = blockRow.row.id\n            blockLocaleData._locale = blockLocale\n            acc.push(blockLocaleData)\n            blockLocaleIndexMap.push(i)\n          }\n        })\n      }\n\n      return acc\n    }, [])\n\n    if (blockLocaleRowsToInsert.length > 0) {\n      await db\n        .insert(adapter.tables[`${tableName}_blocks_${blockName}_locales`])\n        .values(blockLocaleRowsToInsert)\n        .returning()\n    }\n\n    await insertArrays({\n      adapter,\n      arrays: blockRows.map(({ arrays }) => arrays),\n      db,\n      parentRows: insertedBlockRows[blockName],\n    })\n  }\n\n  // //////////////////////////////////\n  // INSERT ARRAYS RECURSIVELY\n  // //////////////////////////////////\n\n  if (operation === 'update') {\n    for (const arrayTableName of Object.keys(rowToInsert.arrays)) {\n      await deleteExistingArrayRows({\n        adapter,\n        db,\n        parentID: insertedRow.id,\n        tableName: arrayTableName,\n      })\n    }\n  }\n\n  await insertArrays({\n    adapter,\n    arrays: [rowToInsert.arrays],\n    db,\n    parentRows: [insertedRow],\n  })\n\n  // //////////////////////////////////\n  // INSERT hasMany SELECTS\n  // //////////////////////////////////\n\n  for (const [selectTableName, tableRows] of Object.entries(selectsToInsert)) {\n    const selectTable = adapter.tables[selectTableName]\n    if (operation === 'update') {\n      await db.delete(selectTable).where(eq(selectTable.parent, insertedRow.id))\n    }\n    await db.insert(selectTable).values(tableRows).returning()\n  }\n\n  // //////////////////////////////////\n  // RETRIEVE NEWLY UPDATED ROW\n  // //////////////////////////////////\n\n  const findManyArgs = buildFindManyArgs({\n    adapter,\n    depth: 0,\n    fields,\n    tableName,\n  })\n\n  findManyArgs.where = eq(adapter.tables[tableName].id, insertedRow.id)\n\n  const doc = await db.query[tableName].findFirst(findManyArgs)\n\n  // //////////////////////////////////\n  // TRANSFORM DATA\n  // //////////////////////////////////\n\n  const result = transform<T>({\n    config: adapter.payload.config,\n    data: doc,\n    fields,\n  })\n\n  return result\n}\n"],"names":["upsertRow","id","adapter","data","db","fields","operation","path","tableName","upsertTarget","where","rowToInsert","transformForWrite","insertedRow","target","tables","row","insert","values","onConflictDoUpdate","set","returning","localesToInsert","relationsToInsert","numbersToInsert","blocksToInsert","selectsToInsert","Object","keys","locales","length","entries","forEach","locale","localeRow","_parentID","_locale","push","relationships","relation","parent","numbers","numberRow","selects","selectTableName","selectRows","blocks","blockName","blockRow","localeTable","delete","eq","relationshipsTableName","deleteExistingRowsByPath","localeColumnName","parentColumnName","parentID","pathColumnName","rows","relationshipsToDelete","numbersTableName","insertedBlockRows","blockRows","map","i","blockLocaleIndexMap","blockLocaleRowsToInsert","reduce","acc","blockLocale","blockLocaleData","insertArrays","arrays","parentRows","arrayTableName","deleteExistingArrayRows","tableRows","selectTable","findManyArgs","buildFindManyArgs","depth","doc","query","findFirst","result","transform","config","payload"],"mappings":"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"}
|
@@ -0,0 +1,64 @@
|
|
1
|
+
/* eslint-disable no-param-reassign */ "use strict";
|
2
|
+
Object.defineProperty(exports, "__esModule", {
|
3
|
+
value: true
|
4
|
+
});
|
5
|
+
Object.defineProperty(exports, "insertArrays", {
|
6
|
+
enumerable: true,
|
7
|
+
get: function() {
|
8
|
+
return insertArrays;
|
9
|
+
}
|
10
|
+
});
|
11
|
+
const insertArrays = async ({ adapter, arrays, db, parentRows })=>{
|
12
|
+
// Maintain a map of flattened rows by table
|
13
|
+
const rowsByTable = {};
|
14
|
+
arrays.forEach((arraysByTable, parentRowIndex)=>{
|
15
|
+
Object.entries(arraysByTable).forEach(([tableName, arrayRows])=>{
|
16
|
+
// If the table doesn't exist in map, initialize it
|
17
|
+
if (!rowsByTable[tableName]) {
|
18
|
+
rowsByTable[tableName] = {
|
19
|
+
arrays: [],
|
20
|
+
locales: [],
|
21
|
+
rows: []
|
22
|
+
};
|
23
|
+
}
|
24
|
+
const parentID = parentRows[parentRowIndex].id;
|
25
|
+
// Add any sub arrays that need to be created
|
26
|
+
// We will call this recursively below
|
27
|
+
arrayRows.forEach((arrayRow)=>{
|
28
|
+
if (Object.keys(arrayRow.arrays).length > 0) {
|
29
|
+
rowsByTable[tableName].arrays.push(arrayRow.arrays);
|
30
|
+
}
|
31
|
+
// Set up parent IDs for both row and locale row
|
32
|
+
arrayRow.row._parentID = parentID;
|
33
|
+
rowsByTable[tableName].rows.push(arrayRow.row);
|
34
|
+
Object.entries(arrayRow.locales).forEach(([arrayRowLocale, arrayRowLocaleData])=>{
|
35
|
+
arrayRowLocaleData._parentID = arrayRow.row.id;
|
36
|
+
arrayRowLocaleData._locale = arrayRowLocale;
|
37
|
+
rowsByTable[tableName].locales.push(arrayRowLocaleData);
|
38
|
+
});
|
39
|
+
});
|
40
|
+
});
|
41
|
+
});
|
42
|
+
// Insert all corresponding arrays
|
43
|
+
// (one insert per array table)
|
44
|
+
for (const [tableName, row] of Object.entries(rowsByTable)){
|
45
|
+
if (row.rows.length > 0) {
|
46
|
+
await db.insert(adapter.tables[tableName]).values(row.rows).returning();
|
47
|
+
}
|
48
|
+
// Insert locale rows
|
49
|
+
if (adapter.tables[`${tableName}_locales`] && row.locales.length > 0) {
|
50
|
+
await db.insert(adapter.tables[`${tableName}_locales`]).values(row.locales).returning();
|
51
|
+
}
|
52
|
+
// If there are sub arrays, call this function recursively
|
53
|
+
if (row.arrays.length > 0) {
|
54
|
+
await insertArrays({
|
55
|
+
adapter,
|
56
|
+
arrays: row.arrays,
|
57
|
+
db,
|
58
|
+
parentRows: row.rows
|
59
|
+
});
|
60
|
+
}
|
61
|
+
}
|
62
|
+
};
|
63
|
+
|
64
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy91cHNlcnRSb3cvaW5zZXJ0QXJyYXlzLnRzIl0sInNvdXJjZXNDb250ZW50IjpbIi8qIGVzbGludC1kaXNhYmxlIG5vLXBhcmFtLXJlYXNzaWduICovXG5pbXBvcnQgdHlwZSB7IEFycmF5Um93VG9JbnNlcnQgfSBmcm9tICcuLi90cmFuc2Zvcm0vd3JpdGUvdHlwZXMnXG5pbXBvcnQgdHlwZSB7IERyaXp6bGVEQiwgUG9zdGdyZXNBZGFwdGVyIH0gZnJvbSAnLi4vdHlwZXMnXG5cbnR5cGUgQXJncyA9IHtcbiAgYWRhcHRlcjogUG9zdGdyZXNBZGFwdGVyXG4gIGFycmF5czoge1xuICAgIFt0YWJsZU5hbWU6IHN0cmluZ106IEFycmF5Um93VG9JbnNlcnRbXVxuICB9W11cbiAgZGI6IERyaXp6bGVEQlxuICBwYXJlbnRSb3dzOiBSZWNvcmQ8c3RyaW5nLCB1bmtub3duPltdXG59XG5cbnR5cGUgUm93c0J5VGFibGUgPSB7XG4gIFt0YWJsZU5hbWU6IHN0cmluZ106IHtcbiAgICBhcnJheXM6IHtcbiAgICAgIFt0YWJsZU5hbWU6IHN0cmluZ106IEFycmF5Um93VG9JbnNlcnRbXVxuICAgIH1bXVxuICAgIGxvY2FsZXM6IFJlY29yZDxzdHJpbmcsIHVua25vd24+W11cbiAgICByb3dzOiBSZWNvcmQ8c3RyaW5nLCB1bmtub3duPltdXG4gIH1cbn1cblxuZXhwb3J0IGNvbnN0IGluc2VydEFycmF5cyA9IGFzeW5jICh7IGFkYXB0ZXIsIGFycmF5cywgZGIsIHBhcmVudFJvd3MgfTogQXJncyk6IFByb21pc2U8dm9pZD4gPT4ge1xuICAvLyBNYWludGFpbiBhIG1hcCBvZiBmbGF0dGVuZWQgcm93cyBieSB0YWJsZVxuICBjb25zdCByb3dzQnlUYWJsZTogUm93c0J5VGFibGUgPSB7fVxuXG4gIGFycmF5cy5mb3JFYWNoKChhcnJheXNCeVRhYmxlLCBwYXJlbnRSb3dJbmRleCkgPT4ge1xuICAgIE9iamVjdC5lbnRyaWVzKGFycmF5c0J5VGFibGUpLmZvckVhY2goKFt0YWJsZU5hbWUsIGFycmF5Um93c10pID0+IHtcbiAgICAgIC8vIElmIHRoZSB0YWJsZSBkb2Vzbid0IGV4aXN0IGluIG1hcCwgaW5pdGlhbGl6ZSBpdFxuICAgICAgaWYgKCFyb3dzQnlUYWJsZVt0YWJsZU5hbWVdKSB7XG4gICAgICAgIHJvd3NCeVRhYmxlW3RhYmxlTmFtZV0gPSB7XG4gICAgICAgICAgYXJyYXlzOiBbXSxcbiAgICAgICAgICBsb2NhbGVzOiBbXSxcbiAgICAgICAgICByb3dzOiBbXSxcbiAgICAgICAgfVxuICAgICAgfVxuXG4gICAgICBjb25zdCBwYXJlbnRJRCA9IHBhcmVudFJvd3NbcGFyZW50Um93SW5kZXhdLmlkXG5cbiAgICAgIC8vIEFkZCBhbnkgc3ViIGFycmF5cyB0aGF0IG5lZWQgdG8gYmUgY3JlYXRlZFxuICAgICAgLy8gV2Ugd2lsbCBjYWxsIHRoaXMgcmVjdXJzaXZlbHkgYmVsb3dcbiAgICAgIGFycmF5Um93cy5mb3JFYWNoKChhcnJheVJvdykgPT4ge1xuICAgICAgICBpZiAoT2JqZWN0LmtleXMoYXJyYXlSb3cuYXJyYXlzKS5sZW5ndGggPiAwKSB7XG4gICAgICAgICAgcm93c0J5VGFibGVbdGFibGVOYW1lXS5hcnJheXMucHVzaChhcnJheVJvdy5hcnJheXMpXG4gICAgICAgIH1cblxuICAgICAgICAvLyBTZXQgdXAgcGFyZW50IElEcyBmb3IgYm90aCByb3cgYW5kIGxvY2FsZSByb3dcbiAgICAgICAgYXJyYXlSb3cucm93Ll9wYXJlbnRJRCA9IHBhcmVudElEXG4gICAgICAgIHJvd3NCeVRhYmxlW3RhYmxlTmFtZV0ucm93cy5wdXNoKGFycmF5Um93LnJvdylcblxuICAgICAgICBPYmplY3QuZW50cmllcyhhcnJheVJvdy5sb2NhbGVzKS5mb3JFYWNoKChbYXJyYXlSb3dMb2NhbGUsIGFycmF5Um93TG9jYWxlRGF0YV0pID0+IHtcbiAgICAgICAgICBhcnJheVJvd0xvY2FsZURhdGEuX3BhcmVudElEID0gYXJyYXlSb3cucm93LmlkXG4gICAgICAgICAgYXJyYXlSb3dMb2NhbGVEYXRhLl9sb2NhbGUgPSBhcnJheVJvd0xvY2FsZVxuICAgICAgICAgIHJvd3NCeVRhYmxlW3RhYmxlTmFtZV0ubG9jYWxlcy5wdXNoKGFycmF5Um93TG9jYWxlRGF0YSlcbiAgICAgICAgfSlcbiAgICAgIH0pXG4gICAgfSlcbiAgfSlcblxuICAvLyBJbnNlcnQgYWxsIGNvcnJlc3BvbmRpbmcgYXJyYXlzXG4gIC8vIChvbmUgaW5zZXJ0IHBlciBhcnJheSB0YWJsZSlcbiAgZm9yIChjb25zdCBbdGFibGVOYW1lLCByb3ddIG9mIE9iamVjdC5lbnRyaWVzKHJvd3NCeVRhYmxlKSkge1xuICAgIGlmIChyb3cucm93cy5sZW5ndGggPiAwKSB7XG4gICAgICBhd2FpdCBkYi5pbnNlcnQoYWRhcHRlci50YWJsZXNbdGFibGVOYW1lXSkudmFsdWVzKHJvdy5yb3dzKS5yZXR1cm5pbmcoKVxuICAgIH1cblxuICAgIC8vIEluc2VydCBsb2NhbGUgcm93c1xuICAgIGlmIChhZGFwdGVyLnRhYmxlc1tgJHt0YWJsZU5hbWV9X2xvY2FsZXNgXSAmJiByb3cubG9jYWxlcy5sZW5ndGggPiAwKSB7XG4gICAgICBhd2FpdCBkYi5pbnNlcnQoYWRhcHRlci50YWJsZXNbYCR7dGFibGVOYW1lfV9sb2NhbGVzYF0pLnZhbHVlcyhyb3cubG9jYWxlcykucmV0dXJuaW5nKClcbiAgICB9XG5cbiAgICAvLyBJZiB0aGVyZSBhcmUgc3ViIGFycmF5cywgY2FsbCB0aGlzIGZ1bmN0aW9uIHJlY3Vyc2l2ZWx5XG4gICAgaWYgKHJvdy5hcnJheXMubGVuZ3RoID4gMCkge1xuICAgICAgYXdhaXQgaW5zZXJ0QXJyYXlzKHtcbiAgICAgICAgYWRhcHRlcixcbiAgICAgICAgYXJyYXlzOiByb3cuYXJyYXlzLFxuICAgICAgICBkYixcbiAgICAgICAgcGFyZW50Um93czogcm93LnJvd3MsXG4gICAgICB9KVxuICAgIH1cbiAgfVxufVxuIl0sIm5hbWVzIjpbImluc2VydEFycmF5cyIsImFkYXB0ZXIiLCJhcnJheXMiLCJkYiIsInBhcmVudFJvd3MiLCJyb3dzQnlUYWJsZSIsImZvckVhY2giLCJhcnJheXNCeVRhYmxlIiwicGFyZW50Um93SW5kZXgiLCJPYmplY3QiLCJlbnRyaWVzIiwidGFibGVOYW1lIiwiYXJyYXlSb3dzIiwibG9jYWxlcyIsInJvd3MiLCJwYXJlbnRJRCIsImlkIiwiYXJyYXlSb3ciLCJrZXlzIiwibGVuZ3RoIiwicHVzaCIsInJvdyIsIl9wYXJlbnRJRCIsImFycmF5Um93TG9jYWxlIiwiYXJyYXlSb3dMb2NhbGVEYXRhIiwiX2xvY2FsZSIsImluc2VydCIsInRhYmxlcyIsInZhbHVlcyIsInJldHVybmluZyJdLCJtYXBwaW5ncyI6IkFBQUEsb0NBQW9DOzs7OytCQXVCdkJBOzs7ZUFBQUE7OztBQUFOLE1BQU1BLGVBQWUsT0FBTyxFQUFFQyxPQUFPLEVBQUVDLE1BQU0sRUFBRUMsRUFBRSxFQUFFQyxVQUFVLEVBQVE7SUFDMUUsNENBQTRDO0lBQzVDLE1BQU1DLGNBQTJCLENBQUM7SUFFbENILE9BQU9JLE9BQU8sQ0FBQyxDQUFDQyxlQUFlQztRQUM3QkMsT0FBT0MsT0FBTyxDQUFDSCxlQUFlRCxPQUFPLENBQUMsQ0FBQyxDQUFDSyxXQUFXQyxVQUFVO1lBQzNELG1EQUFtRDtZQUNuRCxJQUFJLENBQUNQLFdBQVcsQ0FBQ00sVUFBVSxFQUFFO2dCQUMzQk4sV0FBVyxDQUFDTSxVQUFVLEdBQUc7b0JBQ3ZCVCxRQUFRLEVBQUU7b0JBQ1ZXLFNBQVMsRUFBRTtvQkFDWEMsTUFBTSxFQUFFO2dCQUNWO1lBQ0Y7WUFFQSxNQUFNQyxXQUFXWCxVQUFVLENBQUNJLGVBQWUsQ0FBQ1EsRUFBRTtZQUU5Qyw2Q0FBNkM7WUFDN0Msc0NBQXNDO1lBQ3RDSixVQUFVTixPQUFPLENBQUMsQ0FBQ1c7Z0JBQ2pCLElBQUlSLE9BQU9TLElBQUksQ0FBQ0QsU0FBU2YsTUFBTSxFQUFFaUIsTUFBTSxHQUFHLEdBQUc7b0JBQzNDZCxXQUFXLENBQUNNLFVBQVUsQ0FBQ1QsTUFBTSxDQUFDa0IsSUFBSSxDQUFDSCxTQUFTZixNQUFNO2dCQUNwRDtnQkFFQSxnREFBZ0Q7Z0JBQ2hEZSxTQUFTSSxHQUFHLENBQUNDLFNBQVMsR0FBR1A7Z0JBQ3pCVixXQUFXLENBQUNNLFVBQVUsQ0FBQ0csSUFBSSxDQUFDTSxJQUFJLENBQUNILFNBQVNJLEdBQUc7Z0JBRTdDWixPQUFPQyxPQUFPLENBQUNPLFNBQVNKLE9BQU8sRUFBRVAsT0FBTyxDQUFDLENBQUMsQ0FBQ2lCLGdCQUFnQkMsbUJBQW1CO29CQUM1RUEsbUJBQW1CRixTQUFTLEdBQUdMLFNBQVNJLEdBQUcsQ0FBQ0wsRUFBRTtvQkFDOUNRLG1CQUFtQkMsT0FBTyxHQUFHRjtvQkFDN0JsQixXQUFXLENBQUNNLFVBQVUsQ0FBQ0UsT0FBTyxDQUFDTyxJQUFJLENBQUNJO2dCQUN0QztZQUNGO1FBQ0Y7SUFDRjtJQUVBLGtDQUFrQztJQUNsQywrQkFBK0I7SUFDL0IsS0FBSyxNQUFNLENBQUNiLFdBQVdVLElBQUksSUFBSVosT0FBT0MsT0FBTyxDQUFDTCxhQUFjO1FBQzFELElBQUlnQixJQUFJUCxJQUFJLENBQUNLLE1BQU0sR0FBRyxHQUFHO1lBQ3ZCLE1BQU1oQixHQUFHdUIsTUFBTSxDQUFDekIsUUFBUTBCLE1BQU0sQ0FBQ2hCLFVBQVUsRUFBRWlCLE1BQU0sQ0FBQ1AsSUFBSVAsSUFBSSxFQUFFZSxTQUFTO1FBQ3ZFO1FBRUEscUJBQXFCO1FBQ3JCLElBQUk1QixRQUFRMEIsTUFBTSxDQUFDLENBQUMsRUFBRWhCLFVBQVUsUUFBUSxDQUFDLENBQUMsSUFBSVUsSUFBSVIsT0FBTyxDQUFDTSxNQUFNLEdBQUcsR0FBRztZQUNwRSxNQUFNaEIsR0FBR3VCLE1BQU0sQ0FBQ3pCLFFBQVEwQixNQUFNLENBQUMsQ0FBQyxFQUFFaEIsVUFBVSxRQUFRLENBQUMsQ0FBQyxFQUFFaUIsTUFBTSxDQUFDUCxJQUFJUixPQUFPLEVBQUVnQixTQUFTO1FBQ3ZGO1FBRUEsMERBQTBEO1FBQzFELElBQUlSLElBQUluQixNQUFNLENBQUNpQixNQUFNLEdBQUcsR0FBRztZQUN6QixNQUFNbkIsYUFBYTtnQkFDakJDO2dCQUNBQyxRQUFRbUIsSUFBSW5CLE1BQU07Z0JBQ2xCQztnQkFDQUMsWUFBWWlCLElBQUlQLElBQUk7WUFDdEI7UUFDRjtJQUNGO0FBQ0YifQ==
|