@payloadcms/db-postgres 3.0.0-alpha.18 → 3.0.0-alpha.19
Sign up to get free protection for your applications and to get access to all the features.
- package/dist/connect.js +17 -32
- package/dist/create.js +6 -21
- package/dist/createGlobal.js +6 -21
- package/dist/createGlobalVersion.js +10 -25
- package/dist/createMigration.js +11 -26
- package/dist/createVersion.js +10 -25
- package/dist/deleteMany.js +8 -23
- package/dist/deleteOne.js +10 -25
- package/dist/deleteVersions.js +10 -25
- package/dist/destroy.js +2 -12
- package/dist/find/buildFindManyArgs.js +6 -14
- package/dist/find/chainMethods.js +2 -11
- package/dist/find/findMany.js +14 -29
- package/dist/find/traverseFields.js +8 -23
- package/dist/find.js +6 -21
- package/dist/findGlobal.js +6 -21
- package/dist/findGlobalVersions.js +8 -23
- package/dist/findOne.js +6 -21
- package/dist/findVersions.js +8 -23
- package/dist/index.js +72 -87
- package/dist/init.js +17 -32
- package/dist/migrate.js +15 -30
- package/dist/migrateDown.js +12 -22
- package/dist/migrateFresh.js +15 -28
- package/dist/migrateRefresh.js +18 -26
- package/dist/migrateReset.js +13 -21
- package/dist/migrateStatus.js +9 -19
- package/dist/queries/buildAndOrConditions.js +4 -14
- package/dist/queries/buildQuery.js +10 -20
- package/dist/queries/createJSONQuery/convertPathToJSONTraversal.js +4 -14
- package/dist/queries/createJSONQuery/formatJSONPathSegment.js +2 -12
- package/dist/queries/createJSONQuery/index.js +6 -16
- package/dist/queries/getTableColumnFromPath.js +38 -49
- package/dist/queries/operatorMap.js +17 -27
- package/dist/queries/parseParams.js +32 -42
- package/dist/queries/sanitizeQueryValue.js +8 -18
- package/dist/queryDrafts.js +10 -25
- package/dist/schema/build.js +49 -64
- package/dist/schema/createIndex.js +5 -15
- package/dist/schema/idToUUID.js +2 -12
- package/dist/schema/parentIDColumnMap.js +7 -17
- package/dist/schema/setColumnID.js +10 -20
- package/dist/schema/traverseFields.js +62 -77
- package/dist/schema/validateExistingBlockIsIdentical.js +9 -19
- package/dist/transactions/beginTransaction.js +4 -14
- package/dist/transactions/commitTransaction.js +2 -12
- package/dist/transactions/rollbackTransaction.js +2 -12
- package/dist/transform/read/hasManyNumber.js +2 -12
- package/dist/transform/read/hasManyText.js +2 -12
- package/dist/transform/read/index.js +12 -20
- package/dist/transform/read/relationship.js +2 -12
- package/dist/transform/read/traverseFields.js +15 -23
- package/dist/transform/write/array.js +6 -16
- package/dist/transform/write/blocks.js +6 -21
- package/dist/transform/write/index.js +4 -14
- package/dist/transform/write/numbers.js +2 -12
- package/dist/transform/write/relationships.js +4 -14
- package/dist/transform/write/selects.js +4 -14
- package/dist/transform/write/texts.js +2 -12
- package/dist/transform/write/traverseFields.js +30 -45
- package/dist/transform/write/types.js +2 -5
- package/dist/types.js +2 -5
- package/dist/update.js +11 -26
- package/dist/updateGlobal.js +6 -21
- package/dist/updateGlobalVersion.js +10 -25
- package/dist/updateVersion.js +10 -25
- package/dist/upsertRow/deleteExistingArrayRows.js +5 -15
- package/dist/upsertRow/deleteExistingRowsByPath.js +9 -19
- package/dist/upsertRow/index.js +24 -34
- package/dist/upsertRow/insertArrays.js +2 -12
- package/dist/upsertRow/types.js +2 -5
- package/dist/utilities/appendPrefixToKeys.js +2 -12
- package/dist/utilities/createBlocksMap.js +2 -12
- package/dist/utilities/createMigrationTable.js +4 -14
- package/dist/utilities/createRelationshipMap.js +2 -12
- package/dist/utilities/hasLocalesTable.js +5 -15
- package/dist/utilities/isArrayOfRows.js +2 -12
- package/dist/utilities/migrationTableExists.js +4 -14
- package/dist/utilities/parseError.js +6 -14
- package/package.json +4 -4
package/dist/findVersions.js
CHANGED
@@ -1,27 +1,12 @@
|
|
1
|
-
|
2
|
-
|
3
|
-
|
4
|
-
})
|
5
|
-
Object.defineProperty(exports, "findVersions", {
|
6
|
-
enumerable: true,
|
7
|
-
get: function() {
|
8
|
-
return findVersions;
|
9
|
-
}
|
10
|
-
});
|
11
|
-
const _versions = require("payload/versions");
|
12
|
-
const _tosnakecase = /*#__PURE__*/ _interop_require_default(require("to-snake-case"));
|
13
|
-
const _findMany = require("./find/findMany");
|
14
|
-
function _interop_require_default(obj) {
|
15
|
-
return obj && obj.__esModule ? obj : {
|
16
|
-
default: obj
|
17
|
-
};
|
18
|
-
}
|
19
|
-
const findVersions = async function findVersions({ collection, limit, locale, page, pagination, req = {}, skip, sort: sortArg, where }) {
|
1
|
+
import { buildVersionCollectionFields } from 'payload/versions';
|
2
|
+
import toSnakeCase from 'to-snake-case';
|
3
|
+
import { findMany } from './find/findMany';
|
4
|
+
export const findVersions = async function findVersions({ collection, limit, locale, page, pagination, req = {}, skip, sort: sortArg, where }) {
|
20
5
|
const collectionConfig = this.payload.collections[collection].config;
|
21
6
|
const sort = typeof sortArg === 'string' ? sortArg : collectionConfig.defaultSort;
|
22
|
-
const tableName = `_${(
|
23
|
-
const fields =
|
24
|
-
return
|
7
|
+
const tableName = `_${toSnakeCase(collection)}_v`;
|
8
|
+
const fields = buildVersionCollectionFields(collectionConfig);
|
9
|
+
return findMany({
|
25
10
|
adapter: this,
|
26
11
|
fields,
|
27
12
|
limit,
|
@@ -36,4 +21,4 @@ const findVersions = async function findVersions({ collection, limit, locale, pa
|
|
36
21
|
});
|
37
22
|
};
|
38
23
|
|
39
|
-
//# sourceMappingURL=data:application/json;base64,
|
24
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uL3NyYy9maW5kVmVyc2lvbnMudHMiXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHR5cGUgeyBGaW5kVmVyc2lvbnMgfSBmcm9tICdwYXlsb2FkL2RhdGFiYXNlJ1xuaW1wb3J0IHR5cGUgeyBQYXlsb2FkUmVxdWVzdCwgU2FuaXRpemVkQ29sbGVjdGlvbkNvbmZpZyB9IGZyb20gJ3BheWxvYWQvdHlwZXMnXG5cbmltcG9ydCB7IGJ1aWxkVmVyc2lvbkNvbGxlY3Rpb25GaWVsZHMgfSBmcm9tICdwYXlsb2FkL3ZlcnNpb25zJ1xuaW1wb3J0IHRvU25ha2VDYXNlIGZyb20gJ3RvLXNuYWtlLWNhc2UnXG5cbmltcG9ydCB0eXBlIHsgUG9zdGdyZXNBZGFwdGVyIH0gZnJvbSAnLi90eXBlcydcblxuaW1wb3J0IHsgZmluZE1hbnkgfSBmcm9tICcuL2ZpbmQvZmluZE1hbnknXG5cbmV4cG9ydCBjb25zdCBmaW5kVmVyc2lvbnM6IEZpbmRWZXJzaW9ucyA9IGFzeW5jIGZ1bmN0aW9uIGZpbmRWZXJzaW9ucyhcbiAgdGhpczogUG9zdGdyZXNBZGFwdGVyLFxuICB7XG4gICAgY29sbGVjdGlvbixcbiAgICBsaW1pdCxcbiAgICBsb2NhbGUsXG4gICAgcGFnZSxcbiAgICBwYWdpbmF0aW9uLFxuICAgIHJlcSA9IHt9IGFzIFBheWxvYWRSZXF1ZXN0LFxuICAgIHNraXAsXG4gICAgc29ydDogc29ydEFyZyxcbiAgICB3aGVyZSxcbiAgfSxcbikge1xuICBjb25zdCBjb2xsZWN0aW9uQ29uZmlnOiBTYW5pdGl6ZWRDb2xsZWN0aW9uQ29uZmlnID0gdGhpcy5wYXlsb2FkLmNvbGxlY3Rpb25zW2NvbGxlY3Rpb25dLmNvbmZpZ1xuICBjb25zdCBzb3J0ID0gdHlwZW9mIHNvcnRBcmcgPT09ICdzdHJpbmcnID8gc29ydEFyZyA6IGNvbGxlY3Rpb25Db25maWcuZGVmYXVsdFNvcnRcblxuICBjb25zdCB0YWJsZU5hbWUgPSBgXyR7dG9TbmFrZUNhc2UoY29sbGVjdGlvbil9X3ZgXG4gIGNvbnN0IGZpZWxkcyA9IGJ1aWxkVmVyc2lvbkNvbGxlY3Rpb25GaWVsZHMoY29sbGVjdGlvbkNvbmZpZylcblxuICByZXR1cm4gZmluZE1hbnkoe1xuICAgIGFkYXB0ZXI6IHRoaXMsXG4gICAgZmllbGRzLFxuICAgIGxpbWl0LFxuICAgIGxvY2FsZSxcbiAgICBwYWdlLFxuICAgIHBhZ2luYXRpb24sXG4gICAgcmVxLFxuICAgIHNraXAsXG4gICAgc29ydCxcbiAgICB0YWJsZU5hbWUsXG4gICAgd2hlcmUsXG4gIH0pXG59XG4iXSwibmFtZXMiOlsiYnVpbGRWZXJzaW9uQ29sbGVjdGlvbkZpZWxkcyIsInRvU25ha2VDYXNlIiwiZmluZE1hbnkiLCJmaW5kVmVyc2lvbnMiLCJjb2xsZWN0aW9uIiwibGltaXQiLCJsb2NhbGUiLCJwYWdlIiwicGFnaW5hdGlvbiIsInJlcSIsInNraXAiLCJzb3J0Iiwic29ydEFyZyIsIndoZXJlIiwiY29sbGVjdGlvbkNvbmZpZyIsInBheWxvYWQiLCJjb2xsZWN0aW9ucyIsImNvbmZpZyIsImRlZmF1bHRTb3J0IiwidGFibGVOYW1lIiwiZmllbGRzIiwiYWRhcHRlciJdLCJtYXBwaW5ncyI6IkFBR0EsU0FBU0EsNEJBQTRCLFFBQVEsbUJBQWtCO0FBQy9ELE9BQU9DLGlCQUFpQixnQkFBZTtBQUl2QyxTQUFTQyxRQUFRLFFBQVEsa0JBQWlCO0FBRTFDLE9BQU8sTUFBTUMsZUFBNkIsZUFBZUEsYUFFdkQsRUFDRUMsVUFBVSxFQUNWQyxLQUFLLEVBQ0xDLE1BQU0sRUFDTkMsSUFBSSxFQUNKQyxVQUFVLEVBQ1ZDLE1BQU0sQ0FBQyxDQUFtQixFQUMxQkMsSUFBSSxFQUNKQyxNQUFNQyxPQUFPLEVBQ2JDLEtBQUssRUFDTjtJQUVELE1BQU1DLG1CQUE4QyxJQUFJLENBQUNDLE9BQU8sQ0FBQ0MsV0FBVyxDQUFDWixXQUFXLENBQUNhLE1BQU07SUFDL0YsTUFBTU4sT0FBTyxPQUFPQyxZQUFZLFdBQVdBLFVBQVVFLGlCQUFpQkksV0FBVztJQUVqRixNQUFNQyxZQUFZLENBQUMsQ0FBQyxFQUFFbEIsWUFBWUcsWUFBWSxFQUFFLENBQUM7SUFDakQsTUFBTWdCLFNBQVNwQiw2QkFBNkJjO0lBRTVDLE9BQU9aLFNBQVM7UUFDZG1CLFNBQVMsSUFBSTtRQUNiRDtRQUNBZjtRQUNBQztRQUNBQztRQUNBQztRQUNBQztRQUNBQztRQUNBQztRQUNBUTtRQUNBTjtJQUNGO0FBQ0YsRUFBQyJ9
|
package/dist/index.js
CHANGED
@@ -1,56 +1,41 @@
|
|
1
|
-
|
2
|
-
|
3
|
-
|
4
|
-
}
|
5
|
-
|
6
|
-
|
7
|
-
|
8
|
-
|
9
|
-
|
10
|
-
}
|
11
|
-
|
12
|
-
|
13
|
-
|
14
|
-
|
15
|
-
|
16
|
-
|
17
|
-
|
18
|
-
|
19
|
-
|
20
|
-
|
21
|
-
|
22
|
-
|
23
|
-
|
24
|
-
|
25
|
-
|
26
|
-
|
27
|
-
|
28
|
-
|
29
|
-
|
30
|
-
|
31
|
-
|
32
|
-
|
33
|
-
|
34
|
-
|
35
|
-
const _migrateStatus = require("./migrateStatus");
|
36
|
-
const _queryDrafts = require("./queryDrafts");
|
37
|
-
const _beginTransaction = require("./transactions/beginTransaction");
|
38
|
-
const _commitTransaction = require("./transactions/commitTransaction");
|
39
|
-
const _rollbackTransaction = require("./transactions/rollbackTransaction");
|
40
|
-
const _update = require("./update");
|
41
|
-
const _updateGlobal = require("./updateGlobal");
|
42
|
-
const _updateGlobalVersion = require("./updateGlobalVersion");
|
43
|
-
const _updateVersion = require("./updateVersion");
|
44
|
-
function _interop_require_default(obj) {
|
45
|
-
return obj && obj.__esModule ? obj : {
|
46
|
-
default: obj
|
47
|
-
};
|
48
|
-
}
|
49
|
-
function postgresAdapter(args) {
|
1
|
+
import fs from 'fs';
|
2
|
+
import path from 'path';
|
3
|
+
import { createDatabaseAdapter } from 'payload/database';
|
4
|
+
import { connect } from './connect';
|
5
|
+
import { create } from './create';
|
6
|
+
import { createGlobal } from './createGlobal';
|
7
|
+
import { createGlobalVersion } from './createGlobalVersion';
|
8
|
+
import { createMigration } from './createMigration';
|
9
|
+
import { createVersion } from './createVersion';
|
10
|
+
import { deleteMany } from './deleteMany';
|
11
|
+
import { deleteOne } from './deleteOne';
|
12
|
+
import { deleteVersions } from './deleteVersions';
|
13
|
+
import { destroy } from './destroy';
|
14
|
+
import { find } from './find';
|
15
|
+
import { findGlobal } from './findGlobal';
|
16
|
+
import { findGlobalVersions } from './findGlobalVersions';
|
17
|
+
import { findOne } from './findOne';
|
18
|
+
import { findVersions } from './findVersions';
|
19
|
+
import { init } from './init';
|
20
|
+
import { migrate } from './migrate';
|
21
|
+
import { migrateDown } from './migrateDown';
|
22
|
+
import { migrateFresh } from './migrateFresh';
|
23
|
+
import { migrateRefresh } from './migrateRefresh';
|
24
|
+
import { migrateReset } from './migrateReset';
|
25
|
+
import { migrateStatus } from './migrateStatus';
|
26
|
+
import { queryDrafts } from './queryDrafts';
|
27
|
+
import { beginTransaction } from './transactions/beginTransaction';
|
28
|
+
import { commitTransaction } from './transactions/commitTransaction';
|
29
|
+
import { rollbackTransaction } from './transactions/rollbackTransaction';
|
30
|
+
import { updateOne } from './update';
|
31
|
+
import { updateGlobal } from './updateGlobal';
|
32
|
+
import { updateGlobalVersion } from './updateGlobalVersion';
|
33
|
+
import { updateVersion } from './updateVersion';
|
34
|
+
export function postgresAdapter(args) {
|
50
35
|
function adapter({ payload }) {
|
51
36
|
const migrationDir = findMigrationDir(args.migrationDir);
|
52
37
|
const idType = args.idType || 'serial';
|
53
|
-
return
|
38
|
+
return createDatabaseAdapter({
|
54
39
|
name: 'postgres',
|
55
40
|
// Postgres-specific
|
56
41
|
drizzle: undefined,
|
@@ -68,41 +53,41 @@ function postgresAdapter(args) {
|
|
68
53
|
sessions: {},
|
69
54
|
tables: {},
|
70
55
|
// DatabaseAdapter
|
71
|
-
beginTransaction
|
72
|
-
commitTransaction
|
73
|
-
connect
|
74
|
-
create
|
75
|
-
createGlobal
|
76
|
-
createGlobalVersion
|
77
|
-
createMigration
|
78
|
-
createVersion
|
56
|
+
beginTransaction,
|
57
|
+
commitTransaction,
|
58
|
+
connect,
|
59
|
+
create,
|
60
|
+
createGlobal,
|
61
|
+
createGlobalVersion,
|
62
|
+
createMigration,
|
63
|
+
createVersion,
|
79
64
|
/**
|
80
65
|
* This represents how a default ID is treated in Payload as were a field type
|
81
66
|
*/ defaultIDType: idType === 'serial' ? 'number' : 'text',
|
82
|
-
deleteMany
|
83
|
-
deleteOne
|
84
|
-
deleteVersions
|
85
|
-
destroy
|
86
|
-
find
|
87
|
-
findGlobal
|
88
|
-
findGlobalVersions
|
89
|
-
findOne
|
90
|
-
findVersions
|
91
|
-
init
|
92
|
-
migrate
|
93
|
-
migrateDown
|
94
|
-
migrateFresh
|
95
|
-
migrateRefresh
|
96
|
-
migrateReset
|
97
|
-
migrateStatus
|
67
|
+
deleteMany,
|
68
|
+
deleteOne,
|
69
|
+
deleteVersions,
|
70
|
+
destroy,
|
71
|
+
find,
|
72
|
+
findGlobal,
|
73
|
+
findGlobalVersions,
|
74
|
+
findOne,
|
75
|
+
findVersions,
|
76
|
+
init,
|
77
|
+
migrate,
|
78
|
+
migrateDown,
|
79
|
+
migrateFresh,
|
80
|
+
migrateRefresh,
|
81
|
+
migrateReset,
|
82
|
+
migrateStatus,
|
98
83
|
migrationDir,
|
99
84
|
payload,
|
100
|
-
queryDrafts
|
101
|
-
rollbackTransaction
|
102
|
-
updateGlobal
|
103
|
-
updateGlobalVersion
|
104
|
-
updateOne
|
105
|
-
updateVersion
|
85
|
+
queryDrafts,
|
86
|
+
rollbackTransaction,
|
87
|
+
updateGlobal,
|
88
|
+
updateGlobalVersion,
|
89
|
+
updateOne,
|
90
|
+
updateVersion
|
106
91
|
});
|
107
92
|
}
|
108
93
|
return {
|
@@ -125,22 +110,22 @@ function postgresAdapter(args) {
|
|
125
110
|
* @returns
|
126
111
|
*/ function findMigrationDir(migrationDir) {
|
127
112
|
const cwd = process.cwd();
|
128
|
-
const srcDir =
|
129
|
-
const distDir =
|
130
|
-
const relativeMigrations =
|
113
|
+
const srcDir = path.resolve(cwd, 'src/migrations');
|
114
|
+
const distDir = path.resolve(cwd, 'dist/migrations');
|
115
|
+
const relativeMigrations = path.resolve(cwd, 'migrations');
|
131
116
|
// Use arg if provided
|
132
117
|
if (migrationDir) return migrationDir;
|
133
118
|
// Check other common locations
|
134
|
-
if (
|
119
|
+
if (fs.existsSync(srcDir)) {
|
135
120
|
return srcDir;
|
136
121
|
}
|
137
|
-
if (
|
122
|
+
if (fs.existsSync(distDir)) {
|
138
123
|
return distDir;
|
139
124
|
}
|
140
|
-
if (
|
125
|
+
if (fs.existsSync(relativeMigrations)) {
|
141
126
|
return relativeMigrations;
|
142
127
|
}
|
143
128
|
return srcDir;
|
144
129
|
}
|
145
130
|
|
146
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uL3NyYy9pbmRleC50cyJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgdHlwZSB7IFBheWxvYWQgfSBmcm9tICdwYXlsb2FkJ1xuaW1wb3J0IHR5cGUgeyBEYXRhYmFzZUFkYXB0ZXJPYmogfSBmcm9tICdwYXlsb2FkL2RhdGFiYXNlJ1xuXG5pbXBvcnQgZnMgZnJvbSAnZnMnXG5pbXBvcnQgcGF0aCBmcm9tICdwYXRoJ1xuaW1wb3J0IHsgY3JlYXRlRGF0YWJhc2VBZGFwdGVyIH0gZnJvbSAncGF5bG9hZC9kYXRhYmFzZSdcblxuaW1wb3J0IHR5cGUgeyBBcmdzLCBQb3N0Z3Jlc0FkYXB0ZXIgfSBmcm9tICcuL3R5cGVzJ1xuXG5pbXBvcnQgeyBjb25uZWN0IH0gZnJvbSAnLi9jb25uZWN0J1xuaW1wb3J0IHsgY3JlYXRlIH0gZnJvbSAnLi9jcmVhdGUnXG5pbXBvcnQgeyBjcmVhdGVHbG9iYWwgfSBmcm9tICcuL2NyZWF0ZUdsb2JhbCdcbmltcG9ydCB7IGNyZWF0ZUdsb2JhbFZlcnNpb24gfSBmcm9tICcuL2NyZWF0ZUdsb2JhbFZlcnNpb24nXG5pbXBvcnQgeyBjcmVhdGVNaWdyYXRpb24gfSBmcm9tICcuL2NyZWF0ZU1pZ3JhdGlvbidcbmltcG9ydCB7IGNyZWF0ZVZlcnNpb24gfSBmcm9tICcuL2NyZWF0ZVZlcnNpb24nXG5pbXBvcnQgeyBkZWxldGVNYW55IH0gZnJvbSAnLi9kZWxldGVNYW55J1xuaW1wb3J0IHsgZGVsZXRlT25lIH0gZnJvbSAnLi9kZWxldGVPbmUnXG5pbXBvcnQgeyBkZWxldGVWZXJzaW9ucyB9IGZyb20gJy4vZGVsZXRlVmVyc2lvbnMnXG5pbXBvcnQgeyBkZXN0cm95IH0gZnJvbSAnLi9kZXN0cm95J1xuaW1wb3J0IHsgZmluZCB9IGZyb20gJy4vZmluZCdcbmltcG9ydCB7IGZpbmRHbG9iYWwgfSBmcm9tICcuL2ZpbmRHbG9iYWwnXG5pbXBvcnQgeyBmaW5kR2xvYmFsVmVyc2lvbnMgfSBmcm9tICcuL2ZpbmRHbG9iYWxWZXJzaW9ucydcbmltcG9ydCB7IGZpbmRPbmUgfSBmcm9tICcuL2ZpbmRPbmUnXG5pbXBvcnQgeyBmaW5kVmVyc2lvbnMgfSBmcm9tICcuL2ZpbmRWZXJzaW9ucydcbmltcG9ydCB7IGluaXQgfSBmcm9tICcuL2luaXQnXG5pbXBvcnQgeyBtaWdyYXRlIH0gZnJvbSAnLi9taWdyYXRlJ1xuaW1wb3J0IHsgbWlncmF0ZURvd24gfSBmcm9tICcuL21pZ3JhdGVEb3duJ1xuaW1wb3J0IHsgbWlncmF0ZUZyZXNoIH0gZnJvbSAnLi9taWdyYXRlRnJlc2gnXG5pbXBvcnQgeyBtaWdyYXRlUmVmcmVzaCB9IGZyb20gJy4vbWlncmF0ZVJlZnJlc2gnXG5pbXBvcnQgeyBtaWdyYXRlUmVzZXQgfSBmcm9tICcuL21pZ3JhdGVSZXNldCdcbmltcG9ydCB7IG1pZ3JhdGVTdGF0dXMgfSBmcm9tICcuL21pZ3JhdGVTdGF0dXMnXG5pbXBvcnQgeyBxdWVyeURyYWZ0cyB9IGZyb20gJy4vcXVlcnlEcmFmdHMnXG5pbXBvcnQgeyBiZWdpblRyYW5zYWN0aW9uIH0gZnJvbSAnLi90cmFuc2FjdGlvbnMvYmVnaW5UcmFuc2FjdGlvbidcbmltcG9ydCB7IGNvbW1pdFRyYW5zYWN0aW9uIH0gZnJvbSAnLi90cmFuc2FjdGlvbnMvY29tbWl0VHJhbnNhY3Rpb24nXG5pbXBvcnQgeyByb2xsYmFja1RyYW5zYWN0aW9uIH0gZnJvbSAnLi90cmFuc2FjdGlvbnMvcm9sbGJhY2tUcmFuc2FjdGlvbidcbmltcG9ydCB7IHVwZGF0ZU9uZSB9IGZyb20gJy4vdXBkYXRlJ1xuaW1wb3J0IHsgdXBkYXRlR2xvYmFsIH0gZnJvbSAnLi91cGRhdGVHbG9iYWwnXG5pbXBvcnQgeyB1cGRhdGVHbG9iYWxWZXJzaW9uIH0gZnJvbSAnLi91cGRhdGVHbG9iYWxWZXJzaW9uJ1xuaW1wb3J0IHsgdXBkYXRlVmVyc2lvbiB9IGZyb20gJy4vdXBkYXRlVmVyc2lvbidcblxuZXhwb3J0IHR5cGUgeyBNaWdyYXRlRG93bkFyZ3MsIE1pZ3JhdGVVcEFyZ3MgfSBmcm9tICcuL3R5cGVzJ1xuXG5leHBvcnQgZnVuY3Rpb24gcG9zdGdyZXNBZGFwdGVyKGFyZ3M6IEFyZ3MpOiBEYXRhYmFzZUFkYXB0ZXJPYmo8UG9zdGdyZXNBZGFwdGVyPiB7XG4gIGZ1bmN0aW9uIGFkYXB0ZXIoeyBwYXlsb2FkIH06IHsgcGF5bG9hZDogUGF5bG9hZCB9KSB7XG4gICAgY29uc3QgbWlncmF0aW9uRGlyID0gZmluZE1pZ3JhdGlvbkRpcihhcmdzLm1pZ3JhdGlvbkRpcilcbiAgICBjb25zdCBpZFR5cGUgPSBhcmdzLmlkVHlwZSB8fCAnc2VyaWFsJ1xuXG4gICAgcmV0dXJuIGNyZWF0ZURhdGFiYXNlQWRhcHRlcjxQb3N0Z3Jlc0FkYXB0ZXI+
|
131
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../src/index.ts"],"sourcesContent":["import type { Payload } from 'payload'\nimport type { DatabaseAdapterObj } from 'payload/database'\n\nimport fs from 'fs'\nimport path from 'path'\nimport { createDatabaseAdapter } from 'payload/database'\n\nimport type { Args, PostgresAdapter } from './types'\n\nimport { connect } from './connect'\nimport { create } from './create'\nimport { createGlobal } from './createGlobal'\nimport { createGlobalVersion } from './createGlobalVersion'\nimport { createMigration } from './createMigration'\nimport { createVersion } from './createVersion'\nimport { deleteMany } from './deleteMany'\nimport { deleteOne } from './deleteOne'\nimport { deleteVersions } from './deleteVersions'\nimport { destroy } from './destroy'\nimport { find } from './find'\nimport { findGlobal } from './findGlobal'\nimport { findGlobalVersions } from './findGlobalVersions'\nimport { findOne } from './findOne'\nimport { findVersions } from './findVersions'\nimport { init } from './init'\nimport { migrate } from './migrate'\nimport { migrateDown } from './migrateDown'\nimport { migrateFresh } from './migrateFresh'\nimport { migrateRefresh } from './migrateRefresh'\nimport { migrateReset } from './migrateReset'\nimport { migrateStatus } from './migrateStatus'\nimport { queryDrafts } from './queryDrafts'\nimport { beginTransaction } from './transactions/beginTransaction'\nimport { commitTransaction } from './transactions/commitTransaction'\nimport { rollbackTransaction } from './transactions/rollbackTransaction'\nimport { updateOne } from './update'\nimport { updateGlobal } from './updateGlobal'\nimport { updateGlobalVersion } from './updateGlobalVersion'\nimport { updateVersion } from './updateVersion'\n\nexport type { MigrateDownArgs, MigrateUpArgs } from './types'\n\nexport function postgresAdapter(args: Args): DatabaseAdapterObj<PostgresAdapter> {\n  function adapter({ payload }: { payload: Payload }) {\n    const migrationDir = findMigrationDir(args.migrationDir)\n    const idType = args.idType || 'serial'\n\n    return createDatabaseAdapter<PostgresAdapter>({\n      name: 'postgres',\n\n      // Postgres-specific\n      drizzle: undefined,\n      enums: {},\n      fieldConstraints: {},\n      idType,\n      logger: args.logger,\n      pgSchema: undefined,\n      pool: undefined,\n      poolOptions: args.pool,\n      push: args.push,\n      relations: {},\n      schema: {},\n      schemaName: args.schemaName,\n      sessions: {},\n      tables: {},\n\n      // DatabaseAdapter\n      beginTransaction,\n      commitTransaction,\n      connect,\n      create,\n      createGlobal,\n      createGlobalVersion,\n      createMigration,\n      createVersion,\n      /**\n       * This represents how a default ID is treated in Payload as were a field type\n       */\n      defaultIDType: idType === 'serial' ? 'number' : 'text',\n      deleteMany,\n      deleteOne,\n      deleteVersions,\n      destroy,\n      find,\n      findGlobal,\n      findGlobalVersions,\n      findOne,\n      findVersions,\n      init,\n      migrate,\n      migrateDown,\n      migrateFresh,\n      migrateRefresh,\n      migrateReset,\n      migrateStatus,\n      migrationDir,\n      payload,\n      queryDrafts,\n      rollbackTransaction,\n      updateGlobal,\n      updateGlobalVersion,\n      updateOne,\n      updateVersion,\n    })\n  }\n\n  return {\n    defaultIDType: 'number',\n    init: adapter,\n  }\n}\n\n/**\n * Attempt to find migrations directory.\n *\n * Checks for the following directories in order:\n * - `migrationDir` argument from Payload config\n * - `src/migrations`\n * - `dist/migrations`\n * - `migrations`\n *\n * Defaults to `src/migrations`\n *\n * @param migrationDir\n * @returns\n */\nfunction findMigrationDir(migrationDir?: string): string {\n  const cwd = process.cwd()\n  const srcDir = path.resolve(cwd, 'src/migrations')\n  const distDir = path.resolve(cwd, 'dist/migrations')\n  const relativeMigrations = path.resolve(cwd, 'migrations')\n\n  // Use arg if provided\n  if (migrationDir) return migrationDir\n\n  // Check other common locations\n  if (fs.existsSync(srcDir)) {\n    return srcDir\n  }\n\n  if (fs.existsSync(distDir)) {\n    return distDir\n  }\n\n  if (fs.existsSync(relativeMigrations)) {\n    return relativeMigrations\n  }\n\n  return srcDir\n}\n"],"names":["fs","path","createDatabaseAdapter","connect","create","createGlobal","createGlobalVersion","createMigration","createVersion","deleteMany","deleteOne","deleteVersions","destroy","find","findGlobal","findGlobalVersions","findOne","findVersions","init","migrate","migrateDown","migrateFresh","migrateRefresh","migrateReset","migrateStatus","queryDrafts","beginTransaction","commitTransaction","rollbackTransaction","updateOne","updateGlobal","updateGlobalVersion","updateVersion","postgresAdapter","args","adapter","payload","migrationDir","findMigrationDir","idType","name","drizzle","undefined","enums","fieldConstraints","logger","pgSchema","pool","poolOptions","push","relations","schema","schemaName","sessions","tables","defaultIDType","cwd","process","srcDir","resolve","distDir","relativeMigrations","existsSync"],"mappings":"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"}
|
package/dist/init.js
CHANGED
@@ -1,36 +1,21 @@
|
|
1
|
-
/* eslint-disable no-param-reassign */
|
2
|
-
|
3
|
-
|
4
|
-
}
|
5
|
-
|
6
|
-
enumerable: true,
|
7
|
-
get: function() {
|
8
|
-
return init;
|
9
|
-
}
|
10
|
-
});
|
11
|
-
const _pgcore = require("drizzle-orm/pg-core");
|
12
|
-
const _versions = require("payload/versions");
|
13
|
-
const _tosnakecase = /*#__PURE__*/ _interop_require_default(require("to-snake-case"));
|
14
|
-
const _build = require("./schema/build");
|
15
|
-
function _interop_require_default(obj) {
|
16
|
-
return obj && obj.__esModule ? obj : {
|
17
|
-
default: obj
|
18
|
-
};
|
19
|
-
}
|
20
|
-
const init = async function init() {
|
1
|
+
/* eslint-disable no-param-reassign */ import { pgEnum, pgSchema, pgTable } from 'drizzle-orm/pg-core';
|
2
|
+
import { buildVersionCollectionFields, buildVersionGlobalFields } from 'payload/versions';
|
3
|
+
import toSnakeCase from 'to-snake-case';
|
4
|
+
import { buildTable } from './schema/build';
|
5
|
+
export const init = async function init() {
|
21
6
|
if (this.schemaName) {
|
22
|
-
this.pgSchema =
|
7
|
+
this.pgSchema = pgSchema(this.schemaName);
|
23
8
|
} else {
|
24
9
|
this.pgSchema = {
|
25
|
-
table:
|
10
|
+
table: pgTable
|
26
11
|
};
|
27
12
|
}
|
28
13
|
if (this.payload.config.localization) {
|
29
|
-
this.enums.enum__locales =
|
14
|
+
this.enums.enum__locales = pgEnum('_locales', this.payload.config.localization.locales.map(({ code })=>code));
|
30
15
|
}
|
31
16
|
this.payload.config.collections.forEach((collection)=>{
|
32
|
-
const tableName = (
|
33
|
-
|
17
|
+
const tableName = toSnakeCase(collection.slug);
|
18
|
+
buildTable({
|
34
19
|
adapter: this,
|
35
20
|
buildNumbers: true,
|
36
21
|
buildRelationships: true,
|
@@ -43,8 +28,8 @@ const init = async function init() {
|
|
43
28
|
});
|
44
29
|
if (collection.versions) {
|
45
30
|
const versionsTableName = `_${tableName}_v`;
|
46
|
-
const versionFields =
|
47
|
-
|
31
|
+
const versionFields = buildVersionCollectionFields(collection);
|
32
|
+
buildTable({
|
48
33
|
adapter: this,
|
49
34
|
buildNumbers: true,
|
50
35
|
buildRelationships: true,
|
@@ -58,8 +43,8 @@ const init = async function init() {
|
|
58
43
|
}
|
59
44
|
});
|
60
45
|
this.payload.config.globals.forEach((global)=>{
|
61
|
-
const tableName = (
|
62
|
-
|
46
|
+
const tableName = toSnakeCase(global.slug);
|
47
|
+
buildTable({
|
63
48
|
adapter: this,
|
64
49
|
buildNumbers: true,
|
65
50
|
buildRelationships: true,
|
@@ -72,8 +57,8 @@ const init = async function init() {
|
|
72
57
|
});
|
73
58
|
if (global.versions) {
|
74
59
|
const versionsTableName = `_${tableName}_v`;
|
75
|
-
const versionFields =
|
76
|
-
|
60
|
+
const versionFields = buildVersionGlobalFields(global);
|
61
|
+
buildTable({
|
77
62
|
adapter: this,
|
78
63
|
buildNumbers: true,
|
79
64
|
buildRelationships: true,
|
@@ -88,4 +73,4 @@ const init = async function init() {
|
|
88
73
|
});
|
89
74
|
};
|
90
75
|
|
91
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uL3NyYy9pbml0LnRzIl0sInNvdXJjZXNDb250ZW50IjpbIi8qIGVzbGludC1kaXNhYmxlIG5vLXBhcmFtLXJlYXNzaWduICovXG5pbXBvcnQgdHlwZSB7IEluaXQgfSBmcm9tICdwYXlsb2FkL2RhdGFiYXNlJ1xuaW1wb3J0IHR5cGUgeyBTYW5pdGl6ZWRDb2xsZWN0aW9uQ29uZmlnIH0gZnJvbSAncGF5bG9hZC90eXBlcydcblxuaW1wb3J0IHsgcGdFbnVtLCBwZ1NjaGVtYSwgcGdUYWJsZSB9IGZyb20gJ2RyaXp6bGUtb3JtL3BnLWNvcmUnXG5pbXBvcnQgeyBidWlsZFZlcnNpb25Db2xsZWN0aW9uRmllbGRzLCBidWlsZFZlcnNpb25HbG9iYWxGaWVsZHMgfSBmcm9tICdwYXlsb2FkL3ZlcnNpb25zJ1xuaW1wb3J0IHRvU25ha2VDYXNlIGZyb20gJ3RvLXNuYWtlLWNhc2UnXG5cbmltcG9ydCB0eXBlIHsgUG9zdGdyZXNBZGFwdGVyIH0gZnJvbSAnLi90eXBlcydcblxuaW1wb3J0IHsgYnVpbGRUYWJsZSB9IGZyb20gJy4vc2NoZW1hL2J1aWxkJ1xuXG5leHBvcnQgY29uc3QgaW5pdDogSW5pdCA9IGFzeW5jIGZ1bmN0aW9uIGluaXQodGhpczogUG9zdGdyZXNBZGFwdGVyKSB7XG4gIGlmICh0aGlzLnNjaGVtYU5hbWUpIHtcbiAgICB0aGlzLnBnU2NoZW1hID0gcGdTY2hlbWEodGhpcy5zY2hlbWFOYW1lKVxuICB9IGVsc2Uge1xuICAgIHRoaXMucGdTY2hlbWEgPSB7IHRhYmxlOiBwZ1RhYmxlIH1cbiAgfVxuXG4gIGlmICh0aGlzLnBheWxvYWQuY29uZmlnLmxvY2FsaXphdGlvbikge1xuICAgIHRoaXMuZW51bXMuZW51bV9fbG9jYWxlcyA9IHBnRW51bShcbiAgICAgICdfbG9jYWxlcycsXG4gICAgICB0aGlzLnBheWxvYWQuY29uZmlnLmxvY2FsaXphdGlvbi5sb2NhbGVzLm1hcCgoeyBjb2RlIH0pID0+IGNvZGUpIGFzIFtzdHJpbmcsIC4uLnN0cmluZ1tdXSxcbiAgICApXG4gIH1cblxuICB0aGlzLnBheWxvYWQuY29uZmlnLmNvbGxlY3Rpb25zLmZvckVhY2goKGNvbGxlY3Rpb246IFNhbml0aXplZENvbGxlY3Rpb25Db25maWcpID0+IHtcbiAgICBjb25zdCB0YWJsZU5hbWUgPSB0b1NuYWtlQ2FzZShjb2xsZWN0aW9uLnNsdWcpXG5cbiAgICBidWlsZFRhYmxlKHtcbiAgICAgIGFkYXB0ZXI6IHRoaXMsXG4gICAgICBidWlsZE51bWJlcnM6IHRydWUsXG4gICAgICBidWlsZFJlbGF0aW9uc2hpcHM6IHRydWUsXG4gICAgICBidWlsZFRleHRzOiB0cnVlLFxuICAgICAgZGlzYWJsZU5vdE51bGw6ICEhY29sbGVjdGlvbj8udmVyc2lvbnM/
|
76
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uL3NyYy9pbml0LnRzIl0sInNvdXJjZXNDb250ZW50IjpbIi8qIGVzbGludC1kaXNhYmxlIG5vLXBhcmFtLXJlYXNzaWduICovXG5pbXBvcnQgdHlwZSB7IEluaXQgfSBmcm9tICdwYXlsb2FkL2RhdGFiYXNlJ1xuaW1wb3J0IHR5cGUgeyBTYW5pdGl6ZWRDb2xsZWN0aW9uQ29uZmlnIH0gZnJvbSAncGF5bG9hZC90eXBlcydcblxuaW1wb3J0IHsgcGdFbnVtLCBwZ1NjaGVtYSwgcGdUYWJsZSB9IGZyb20gJ2RyaXp6bGUtb3JtL3BnLWNvcmUnXG5pbXBvcnQgeyBidWlsZFZlcnNpb25Db2xsZWN0aW9uRmllbGRzLCBidWlsZFZlcnNpb25HbG9iYWxGaWVsZHMgfSBmcm9tICdwYXlsb2FkL3ZlcnNpb25zJ1xuaW1wb3J0IHRvU25ha2VDYXNlIGZyb20gJ3RvLXNuYWtlLWNhc2UnXG5cbmltcG9ydCB0eXBlIHsgUG9zdGdyZXNBZGFwdGVyIH0gZnJvbSAnLi90eXBlcydcblxuaW1wb3J0IHsgYnVpbGRUYWJsZSB9IGZyb20gJy4vc2NoZW1hL2J1aWxkJ1xuXG5leHBvcnQgY29uc3QgaW5pdDogSW5pdCA9IGFzeW5jIGZ1bmN0aW9uIGluaXQodGhpczogUG9zdGdyZXNBZGFwdGVyKSB7XG4gIGlmICh0aGlzLnNjaGVtYU5hbWUpIHtcbiAgICB0aGlzLnBnU2NoZW1hID0gcGdTY2hlbWEodGhpcy5zY2hlbWFOYW1lKVxuICB9IGVsc2Uge1xuICAgIHRoaXMucGdTY2hlbWEgPSB7IHRhYmxlOiBwZ1RhYmxlIH1cbiAgfVxuXG4gIGlmICh0aGlzLnBheWxvYWQuY29uZmlnLmxvY2FsaXphdGlvbikge1xuICAgIHRoaXMuZW51bXMuZW51bV9fbG9jYWxlcyA9IHBnRW51bShcbiAgICAgICdfbG9jYWxlcycsXG4gICAgICB0aGlzLnBheWxvYWQuY29uZmlnLmxvY2FsaXphdGlvbi5sb2NhbGVzLm1hcCgoeyBjb2RlIH0pID0+IGNvZGUpIGFzIFtzdHJpbmcsIC4uLnN0cmluZ1tdXSxcbiAgICApXG4gIH1cblxuICB0aGlzLnBheWxvYWQuY29uZmlnLmNvbGxlY3Rpb25zLmZvckVhY2goKGNvbGxlY3Rpb246IFNhbml0aXplZENvbGxlY3Rpb25Db25maWcpID0+IHtcbiAgICBjb25zdCB0YWJsZU5hbWUgPSB0b1NuYWtlQ2FzZShjb2xsZWN0aW9uLnNsdWcpXG5cbiAgICBidWlsZFRhYmxlKHtcbiAgICAgIGFkYXB0ZXI6IHRoaXMsXG4gICAgICBidWlsZE51bWJlcnM6IHRydWUsXG4gICAgICBidWlsZFJlbGF0aW9uc2hpcHM6IHRydWUsXG4gICAgICBidWlsZFRleHRzOiB0cnVlLFxuICAgICAgZGlzYWJsZU5vdE51bGw6ICEhY29sbGVjdGlvbj8udmVyc2lvbnM/LmRyYWZ0cyxcbiAgICAgIGRpc2FibGVVbmlxdWU6IGZhbHNlLFxuICAgICAgZmllbGRzOiBjb2xsZWN0aW9uLmZpZWxkcyxcbiAgICAgIHRhYmxlTmFtZSxcbiAgICAgIHRpbWVzdGFtcHM6IGNvbGxlY3Rpb24udGltZXN0YW1wcyxcbiAgICB9KVxuXG4gICAgaWYgKGNvbGxlY3Rpb24udmVyc2lvbnMpIHtcbiAgICAgIGNvbnN0IHZlcnNpb25zVGFibGVOYW1lID0gYF8ke3RhYmxlTmFtZX1fdmBcbiAgICAgIGNvbnN0IHZlcnNpb25GaWVsZHMgPSBidWlsZFZlcnNpb25Db2xsZWN0aW9uRmllbGRzKGNvbGxlY3Rpb24pXG5cbiAgICAgIGJ1aWxkVGFibGUoe1xuICAgICAgICBhZGFwdGVyOiB0aGlzLFxuICAgICAgICBidWlsZE51bWJlcnM6IHRydWUsXG4gICAgICAgIGJ1aWxkUmVsYXRpb25zaGlwczogdHJ1ZSxcbiAgICAgICAgYnVpbGRUZXh0czogdHJ1ZSxcbiAgICAgICAgZGlzYWJsZU5vdE51bGw6ICEhY29sbGVjdGlvbi52ZXJzaW9ucz8uZHJhZnRzLFxuICAgICAgICBkaXNhYmxlVW5pcXVlOiB0cnVlLFxuICAgICAgICBmaWVsZHM6IHZlcnNpb25GaWVsZHMsXG4gICAgICAgIHRhYmxlTmFtZTogdmVyc2lvbnNUYWJsZU5hbWUsXG4gICAgICAgIHRpbWVzdGFtcHM6IHRydWUsXG4gICAgICB9KVxuICAgIH1cbiAgfSlcblxuICB0aGlzLnBheWxvYWQuY29uZmlnLmdsb2JhbHMuZm9yRWFjaCgoZ2xvYmFsKSA9PiB7XG4gICAgY29uc3QgdGFibGVOYW1lID0gdG9TbmFrZUNhc2UoZ2xvYmFsLnNsdWcpXG5cbiAgICBidWlsZFRhYmxlKHtcbiAgICAgIGFkYXB0ZXI6IHRoaXMsXG4gICAgICBidWlsZE51bWJlcnM6IHRydWUsXG4gICAgICBidWlsZFJlbGF0aW9uc2hpcHM6IHRydWUsXG4gICAgICBidWlsZFRleHRzOiB0cnVlLFxuICAgICAgZGlzYWJsZU5vdE51bGw6ICEhZ2xvYmFsPy52ZXJzaW9ucz8uZHJhZnRzLFxuICAgICAgZGlzYWJsZVVuaXF1ZTogZmFsc2UsXG4gICAgICBmaWVsZHM6IGdsb2JhbC5maWVsZHMsXG4gICAgICB0YWJsZU5hbWUsXG4gICAgICB0aW1lc3RhbXBzOiBmYWxzZSxcbiAgICB9KVxuXG4gICAgaWYgKGdsb2JhbC52ZXJzaW9ucykge1xuICAgICAgY29uc3QgdmVyc2lvbnNUYWJsZU5hbWUgPSBgXyR7dGFibGVOYW1lfV92YFxuICAgICAgY29uc3QgdmVyc2lvbkZpZWxkcyA9IGJ1aWxkVmVyc2lvbkdsb2JhbEZpZWxkcyhnbG9iYWwpXG5cbiAgICAgIGJ1aWxkVGFibGUoe1xuICAgICAgICBhZGFwdGVyOiB0aGlzLFxuICAgICAgICBidWlsZE51bWJlcnM6IHRydWUsXG4gICAgICAgIGJ1aWxkUmVsYXRpb25zaGlwczogdHJ1ZSxcbiAgICAgICAgYnVpbGRUZXh0czogdHJ1ZSxcbiAgICAgICAgZGlzYWJsZU5vdE51bGw6ICEhZ2xvYmFsLnZlcnNpb25zPy5kcmFmdHMsXG4gICAgICAgIGRpc2FibGVVbmlxdWU6IHRydWUsXG4gICAgICAgIGZpZWxkczogdmVyc2lvbkZpZWxkcyxcbiAgICAgICAgdGFibGVOYW1lOiB2ZXJzaW9uc1RhYmxlTmFtZSxcbiAgICAgICAgdGltZXN0YW1wczogdHJ1ZSxcbiAgICAgIH0pXG4gICAgfVxuICB9KVxufVxuIl0sIm5hbWVzIjpbInBnRW51bSIsInBnU2NoZW1hIiwicGdUYWJsZSIsImJ1aWxkVmVyc2lvbkNvbGxlY3Rpb25GaWVsZHMiLCJidWlsZFZlcnNpb25HbG9iYWxGaWVsZHMiLCJ0b1NuYWtlQ2FzZSIsImJ1aWxkVGFibGUiLCJpbml0Iiwic2NoZW1hTmFtZSIsInRhYmxlIiwicGF5bG9hZCIsImNvbmZpZyIsImxvY2FsaXphdGlvbiIsImVudW1zIiwiZW51bV9fbG9jYWxlcyIsImxvY2FsZXMiLCJtYXAiLCJjb2RlIiwiY29sbGVjdGlvbnMiLCJmb3JFYWNoIiwiY29sbGVjdGlvbiIsInRhYmxlTmFtZSIsInNsdWciLCJhZGFwdGVyIiwiYnVpbGROdW1iZXJzIiwiYnVpbGRSZWxhdGlvbnNoaXBzIiwiYnVpbGRUZXh0cyIsImRpc2FibGVOb3ROdWxsIiwidmVyc2lvbnMiLCJkcmFmdHMiLCJkaXNhYmxlVW5pcXVlIiwiZmllbGRzIiwidGltZXN0YW1wcyIsInZlcnNpb25zVGFibGVOYW1lIiwidmVyc2lvbkZpZWxkcyIsImdsb2JhbHMiLCJnbG9iYWwiXSwibWFwcGluZ3MiOiJBQUFBLG9DQUFvQyxHQUlwQyxTQUFTQSxNQUFNLEVBQUVDLFFBQVEsRUFBRUMsT0FBTyxRQUFRLHNCQUFxQjtBQUMvRCxTQUFTQyw0QkFBNEIsRUFBRUMsd0JBQXdCLFFBQVEsbUJBQWtCO0FBQ3pGLE9BQU9DLGlCQUFpQixnQkFBZTtBQUl2QyxTQUFTQyxVQUFVLFFBQVEsaUJBQWdCO0FBRTNDLE9BQU8sTUFBTUMsT0FBYSxlQUFlQTtJQUN2QyxJQUFJLElBQUksQ0FBQ0MsVUFBVSxFQUFFO1FBQ25CLElBQUksQ0FBQ1AsUUFBUSxHQUFHQSxTQUFTLElBQUksQ0FBQ08sVUFBVTtJQUMxQyxPQUFPO1FBQ0wsSUFBSSxDQUFDUCxRQUFRLEdBQUc7WUFBRVEsT0FBT1A7UUFBUTtJQUNuQztJQUVBLElBQUksSUFBSSxDQUFDUSxPQUFPLENBQUNDLE1BQU0sQ0FBQ0MsWUFBWSxFQUFFO1FBQ3BDLElBQUksQ0FBQ0MsS0FBSyxDQUFDQyxhQUFhLEdBQUdkLE9BQ3pCLFlBQ0EsSUFBSSxDQUFDVSxPQUFPLENBQUNDLE1BQU0sQ0FBQ0MsWUFBWSxDQUFDRyxPQUFPLENBQUNDLEdBQUcsQ0FBQyxDQUFDLEVBQUVDLElBQUksRUFBRSxHQUFLQTtJQUUvRDtJQUVBLElBQUksQ0FBQ1AsT0FBTyxDQUFDQyxNQUFNLENBQUNPLFdBQVcsQ0FBQ0MsT0FBTyxDQUFDLENBQUNDO1FBQ3ZDLE1BQU1DLFlBQVloQixZQUFZZSxXQUFXRSxJQUFJO1FBRTdDaEIsV0FBVztZQUNUaUIsU0FBUyxJQUFJO1lBQ2JDLGNBQWM7WUFDZEMsb0JBQW9CO1lBQ3BCQyxZQUFZO1lBQ1pDLGdCQUFnQixDQUFDLENBQUNQLFlBQVlRLFVBQVVDO1lBQ3hDQyxlQUFlO1lBQ2ZDLFFBQVFYLFdBQVdXLE1BQU07WUFDekJWO1lBQ0FXLFlBQVlaLFdBQVdZLFVBQVU7UUFDbkM7UUFFQSxJQUFJWixXQUFXUSxRQUFRLEVBQUU7WUFDdkIsTUFBTUssb0JBQW9CLENBQUMsQ0FBQyxFQUFFWixVQUFVLEVBQUUsQ0FBQztZQUMzQyxNQUFNYSxnQkFBZ0IvQiw2QkFBNkJpQjtZQUVuRGQsV0FBVztnQkFDVGlCLFNBQVMsSUFBSTtnQkFDYkMsY0FBYztnQkFDZEMsb0JBQW9CO2dCQUNwQkMsWUFBWTtnQkFDWkMsZ0JBQWdCLENBQUMsQ0FBQ1AsV0FBV1EsUUFBUSxFQUFFQztnQkFDdkNDLGVBQWU7Z0JBQ2ZDLFFBQVFHO2dCQUNSYixXQUFXWTtnQkFDWEQsWUFBWTtZQUNkO1FBQ0Y7SUFDRjtJQUVBLElBQUksQ0FBQ3RCLE9BQU8sQ0FBQ0MsTUFBTSxDQUFDd0IsT0FBTyxDQUFDaEIsT0FBTyxDQUFDLENBQUNpQjtRQUNuQyxNQUFNZixZQUFZaEIsWUFBWStCLE9BQU9kLElBQUk7UUFFekNoQixXQUFXO1lBQ1RpQixTQUFTLElBQUk7WUFDYkMsY0FBYztZQUNkQyxvQkFBb0I7WUFDcEJDLFlBQVk7WUFDWkMsZ0JBQWdCLENBQUMsQ0FBQ1MsUUFBUVIsVUFBVUM7WUFDcENDLGVBQWU7WUFDZkMsUUFBUUssT0FBT0wsTUFBTTtZQUNyQlY7WUFDQVcsWUFBWTtRQUNkO1FBRUEsSUFBSUksT0FBT1IsUUFBUSxFQUFFO1lBQ25CLE1BQU1LLG9CQUFvQixDQUFDLENBQUMsRUFBRVosVUFBVSxFQUFFLENBQUM7WUFDM0MsTUFBTWEsZ0JBQWdCOUIseUJBQXlCZ0M7WUFFL0M5QixXQUFXO2dCQUNUaUIsU0FBUyxJQUFJO2dCQUNiQyxjQUFjO2dCQUNkQyxvQkFBb0I7Z0JBQ3BCQyxZQUFZO2dCQUNaQyxnQkFBZ0IsQ0FBQyxDQUFDUyxPQUFPUixRQUFRLEVBQUVDO2dCQUNuQ0MsZUFBZTtnQkFDZkMsUUFBUUc7Z0JBQ1JiLFdBQVdZO2dCQUNYRCxZQUFZO1lBQ2Q7UUFDRjtJQUNGO0FBQ0YsRUFBQyJ9
|
package/dist/migrate.js
CHANGED
@@ -1,26 +1,11 @@
|
|
1
|
-
/* eslint-disable no-restricted-syntax, no-await-in-loop */
|
2
|
-
|
3
|
-
|
4
|
-
}
|
5
|
-
|
6
|
-
|
7
|
-
get: function() {
|
8
|
-
return migrate;
|
9
|
-
}
|
10
|
-
});
|
11
|
-
const _database = require("payload/database");
|
12
|
-
const _prompts = /*#__PURE__*/ _interop_require_default(require("prompts"));
|
13
|
-
const _createMigrationTable = require("./utilities/createMigrationTable");
|
14
|
-
const _migrationTableExists = require("./utilities/migrationTableExists");
|
15
|
-
const _parseError = require("./utilities/parseError");
|
16
|
-
function _interop_require_default(obj) {
|
17
|
-
return obj && obj.__esModule ? obj : {
|
18
|
-
default: obj
|
19
|
-
};
|
20
|
-
}
|
21
|
-
async function migrate() {
|
1
|
+
/* eslint-disable no-restricted-syntax, no-await-in-loop */ import { commitTransaction, initTransaction, killTransaction, readMigrationFiles } from 'payload/database';
|
2
|
+
import prompts from 'prompts';
|
3
|
+
import { createMigrationTable } from './utilities/createMigrationTable';
|
4
|
+
import { migrationTableExists } from './utilities/migrationTableExists';
|
5
|
+
import { parseError } from './utilities/parseError';
|
6
|
+
export async function migrate() {
|
22
7
|
const { payload } = this;
|
23
|
-
const migrationFiles = await
|
8
|
+
const migrationFiles = await readMigrationFiles({
|
24
9
|
payload
|
25
10
|
});
|
26
11
|
if (!migrationFiles.length) {
|
@@ -31,7 +16,7 @@ async function migrate() {
|
|
31
16
|
}
|
32
17
|
let latestBatch = 0;
|
33
18
|
let migrationsInDB = [];
|
34
|
-
const hasMigrationTable = await
|
19
|
+
const hasMigrationTable = await migrationTableExists(this.drizzle);
|
35
20
|
if (hasMigrationTable) {
|
36
21
|
({ docs: migrationsInDB } = await payload.find({
|
37
22
|
collection: 'payload-migrations',
|
@@ -42,10 +27,10 @@ async function migrate() {
|
|
42
27
|
latestBatch = Number(migrationsInDB[0]?.batch);
|
43
28
|
}
|
44
29
|
} else {
|
45
|
-
await
|
30
|
+
await createMigrationTable(this);
|
46
31
|
}
|
47
32
|
if (migrationsInDB.find((m)=>m.batch === -1)) {
|
48
|
-
const { confirm: runMigrations } = await (
|
33
|
+
const { confirm: runMigrations } = await prompts({
|
49
34
|
name: 'confirm',
|
50
35
|
type: 'confirm',
|
51
36
|
initial: false,
|
@@ -82,7 +67,7 @@ async function runMigrationFile(payload, migration, batch) {
|
|
82
67
|
const pgAdapter = payload.db;
|
83
68
|
const drizzleJSON = generateDrizzleJson(pgAdapter.schema);
|
84
69
|
try {
|
85
|
-
await
|
70
|
+
await initTransaction(req);
|
86
71
|
await migration.up({
|
87
72
|
payload,
|
88
73
|
req
|
@@ -99,14 +84,14 @@ async function runMigrationFile(payload, migration, batch) {
|
|
99
84
|
},
|
100
85
|
req
|
101
86
|
});
|
102
|
-
await
|
87
|
+
await commitTransaction(req);
|
103
88
|
} catch (err) {
|
104
|
-
await
|
89
|
+
await killTransaction(req);
|
105
90
|
payload.logger.error({
|
106
91
|
err,
|
107
|
-
msg:
|
92
|
+
msg: parseError(err, `Error running migration ${migration.name}`)
|
108
93
|
});
|
109
94
|
}
|
110
95
|
}
|
111
96
|
|
112
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uL3NyYy9taWdyYXRlLnRzIl0sInNvdXJjZXNDb250ZW50IjpbIi8qIGVzbGludC1kaXNhYmxlIG5vLXJlc3RyaWN0ZWQtc3ludGF4LCBuby1hd2FpdC1pbi1sb29wICovXG5pbXBvcnQgdHlwZSB7IFBheWxvYWQgfSBmcm9tICdwYXlsb2FkJ1xuaW1wb3J0IHR5cGUgeyBNaWdyYXRpb24gfSBmcm9tICdwYXlsb2FkL2RhdGFiYXNlJ1xuaW1wb3J0IHR5cGUgeyBQYXlsb2FkUmVxdWVzdCB9IGZyb20gJ3BheWxvYWQvdHlwZXMnXG5cbmltcG9ydCB7XG4gIGNvbW1pdFRyYW5zYWN0aW9uLFxuICBpbml0VHJhbnNhY3Rpb24sXG4gIGtpbGxUcmFuc2FjdGlvbixcbiAgcmVhZE1pZ3JhdGlvbkZpbGVzLFxufSBmcm9tICdwYXlsb2FkL2RhdGFiYXNlJ1xuaW1wb3J0IHByb21wdHMgZnJvbSAncHJvbXB0cydcblxuaW1wb3J0IHR5cGUgeyBQb3N0Z3Jlc0FkYXB0ZXIgfSBmcm9tICcuL3R5cGVzJ1xuXG5pbXBvcnQgeyBjcmVhdGVNaWdyYXRpb25UYWJsZSB9IGZyb20gJy4vdXRpbGl0aWVzL2NyZWF0ZU1pZ3JhdGlvblRhYmxlJ1xuaW1wb3J0IHsgbWlncmF0aW9uVGFibGVFeGlzdHMgfSBmcm9tICcuL3V0aWxpdGllcy9taWdyYXRpb25UYWJsZUV4aXN0cydcbmltcG9ydCB7IHBhcnNlRXJyb3IgfSBmcm9tICcuL3V0aWxpdGllcy9wYXJzZUVycm9yJ1xuXG5leHBvcnQgYXN5bmMgZnVuY3Rpb24gbWlncmF0ZSh0aGlzOiBQb3N0Z3Jlc0FkYXB0ZXIpOiBQcm9taXNlPHZvaWQ+IHtcbiAgY29uc3QgeyBwYXlsb2FkIH0gPSB0aGlzXG4gIGNvbnN0IG1pZ3JhdGlvbkZpbGVzID0gYXdhaXQgcmVhZE1pZ3JhdGlvbkZpbGVzKHsgcGF5bG9hZCB9KVxuXG4gIGlmICghbWlncmF0aW9uRmlsZXMubGVuZ3RoKSB7XG4gICAgcGF5bG9hZC5sb2dnZXIuaW5mbyh7IG1zZzogJ05vIG1pZ3JhdGlvbnMgdG8gcnVuLicgfSlcbiAgICByZXR1cm5cbiAgfVxuXG4gIGxldCBsYXRlc3RCYXRjaCA9IDBcbiAgbGV0IG1pZ3JhdGlvbnNJbkRCID0gW11cblxuICBjb25zdCBoYXNNaWdyYXRpb25UYWJsZSA9IGF3YWl0IG1pZ3JhdGlvblRhYmxlRXhpc3RzKHRoaXMuZHJpenpsZSlcblxuICBpZiAoaGFzTWlncmF0aW9uVGFibGUpIHtcbiAgICA7KHsgZG9jczogbWlncmF0aW9uc0luREIgfSA9IGF3YWl0IHBheWxvYWQuZmluZCh7XG4gICAgICBjb2xsZWN0aW9uOiAncGF5bG9hZC1taWdyYXRpb25zJyxcbiAgICAgIGxpbWl0OiAwLFxuICAgICAgc29ydDogJy1uYW1lJyxcbiAgICB9KSlcbiAgICBpZiAoTnVtYmVyKG1pZ3JhdGlvbnNJbkRCPy5bMF0/LmJhdGNoKSA+IDApIHtcbiAgICAgIGxhdGVzdEJhdGNoID0gTnVtYmVyKG1pZ3JhdGlvbnNJbkRCWzBdPy5iYXRjaClcbiAgICB9XG4gIH0gZWxzZSB7XG4gICAgYXdhaXQgY3JlYXRlTWlncmF0aW9uVGFibGUodGhpcylcbiAgfVxuXG4gIGlmIChtaWdyYXRpb25zSW5EQi5maW5kKChtKSA9PiBtLmJhdGNoID09PSAtMSkpIHtcbiAgICBjb25zdCB7IGNvbmZpcm06IHJ1bk1pZ3JhdGlvbnMgfSA9IGF3YWl0IHByb21wdHMoXG4gICAgICB7XG4gICAgICAgIG5hbWU6ICdjb25maXJtJyxcbiAgICAgICAgdHlwZTogJ2NvbmZpcm0nLFxuICAgICAgICBpbml0aWFsOiBmYWxzZSxcbiAgICAgICAgbWVzc2FnZTpcbiAgICAgICAgICBcIkl0IGxvb2tzIGxpa2UgeW91J3ZlIHJ1biBQYXlsb2FkIGluIGRldiBtb2RlLCBtZWFuaW5nIHlvdSd2ZSBkeW5hbWljYWxseSBwdXNoZWQgY2hhbmdlcyB0byB5b3VyIGRhdGFiYXNlLlxcblxcblwiICtcbiAgICAgICAgICBcIklmIHlvdSdkIGxpa2UgdG8gcnVuIG1pZ3JhdGlvbnMsIGRhdGEgbG9zcyB3aWxsIG9jY3VyLiBXb3VsZCB5b3UgbGlrZSB0byBwcm9jZWVkP1wiLFxuICAgICAgfSxcbiAgICAgIHtcbiAgICAgICAgb25DYW5jZWw6ICgpID0+
|
97
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../src/migrate.ts"],"sourcesContent":["/* eslint-disable no-restricted-syntax, no-await-in-loop */\nimport type { Payload } from 'payload'\nimport type { Migration } from 'payload/database'\nimport type { PayloadRequest } from 'payload/types'\n\nimport {\n  commitTransaction,\n  initTransaction,\n  killTransaction,\n  readMigrationFiles,\n} from 'payload/database'\nimport prompts from 'prompts'\n\nimport type { PostgresAdapter } from './types'\n\nimport { createMigrationTable } from './utilities/createMigrationTable'\nimport { migrationTableExists } from './utilities/migrationTableExists'\nimport { parseError } from './utilities/parseError'\n\nexport async function migrate(this: PostgresAdapter): Promise<void> {\n  const { payload } = this\n  const migrationFiles = await readMigrationFiles({ payload })\n\n  if (!migrationFiles.length) {\n    payload.logger.info({ msg: 'No migrations to run.' })\n    return\n  }\n\n  let latestBatch = 0\n  let migrationsInDB = []\n\n  const hasMigrationTable = await migrationTableExists(this.drizzle)\n\n  if (hasMigrationTable) {\n    ;({ docs: migrationsInDB } = await payload.find({\n      collection: 'payload-migrations',\n      limit: 0,\n      sort: '-name',\n    }))\n    if (Number(migrationsInDB?.[0]?.batch) > 0) {\n      latestBatch = Number(migrationsInDB[0]?.batch)\n    }\n  } else {\n    await createMigrationTable(this)\n  }\n\n  if (migrationsInDB.find((m) => m.batch === -1)) {\n    const { confirm: runMigrations } = await prompts(\n      {\n        name: 'confirm',\n        type: 'confirm',\n        initial: false,\n        message:\n          \"It looks like you've run Payload in dev mode, meaning you've dynamically pushed changes to your database.\\n\\n\" +\n          \"If you'd like to run migrations, data loss will occur. Would you like to proceed?\",\n      },\n      {\n        onCancel: () => {\n          process.exit(0)\n        },\n      },\n    )\n\n    if (!runMigrations) {\n      process.exit(0)\n    }\n  }\n\n  const newBatch = latestBatch + 1\n\n  // Execute 'up' function for each migration sequentially\n  for (const migration of migrationFiles) {\n    const alreadyRan = migrationsInDB.find((existing) => existing.name === migration.name)\n\n    // If already ran, skip\n    if (alreadyRan) {\n      continue // eslint-disable-line no-continue\n    }\n\n    await runMigrationFile(payload, migration, newBatch)\n  }\n}\n\nasync function runMigrationFile(payload: Payload, migration: Migration, batch: number) {\n  const { generateDrizzleJson } = require('drizzle-kit/payload')\n\n  const start = Date.now()\n  const req = { payload } as PayloadRequest\n\n  payload.logger.info({ msg: `Migrating: ${migration.name}` })\n\n  const pgAdapter = payload.db as PostgresAdapter\n  const drizzleJSON = generateDrizzleJson(pgAdapter.schema)\n\n  try {\n    await initTransaction(req)\n    await migration.up({ payload, req })\n    payload.logger.info({ msg: `Migrated:  ${migration.name} (${Date.now() - start}ms)` })\n    await payload.create({\n      collection: 'payload-migrations',\n      data: {\n        name: migration.name,\n        batch,\n        schema: drizzleJSON,\n      },\n      req,\n    })\n    await commitTransaction(req)\n  } catch (err: unknown) {\n    await killTransaction(req)\n    payload.logger.error({\n      err,\n      msg: parseError(err, `Error running migration ${migration.name}`),\n    })\n  }\n}\n"],"names":["commitTransaction","initTransaction","killTransaction","readMigrationFiles","prompts","createMigrationTable","migrationTableExists","parseError","migrate","payload","migrationFiles","length","logger","info","msg","latestBatch","migrationsInDB","hasMigrationTable","drizzle","docs","find","collection","limit","sort","Number","batch","m","confirm","runMigrations","name","type","initial","message","onCancel","process","exit","newBatch","migration","alreadyRan","existing","runMigrationFile","generateDrizzleJson","require","start","Date","now","req","pgAdapter","db","drizzleJSON","schema","up","create","data","err","error"],"mappings":"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"}
|
package/dist/migrateDown.js
CHANGED
@@ -1,22 +1,12 @@
|
|
1
|
-
/* eslint-disable no-restricted-syntax, no-await-in-loop */
|
2
|
-
|
3
|
-
|
4
|
-
|
5
|
-
Object.defineProperty(exports, "migrateDown", {
|
6
|
-
enumerable: true,
|
7
|
-
get: function() {
|
8
|
-
return migrateDown;
|
9
|
-
}
|
10
|
-
});
|
11
|
-
const _database = require("payload/database");
|
12
|
-
const _migrationTableExists = require("./utilities/migrationTableExists");
|
13
|
-
const _parseError = require("./utilities/parseError");
|
14
|
-
async function migrateDown() {
|
1
|
+
/* eslint-disable no-restricted-syntax, no-await-in-loop */ import { commitTransaction, getMigrations, initTransaction, killTransaction, readMigrationFiles } from 'payload/database';
|
2
|
+
import { migrationTableExists } from './utilities/migrationTableExists';
|
3
|
+
import { parseError } from './utilities/parseError';
|
4
|
+
export async function migrateDown() {
|
15
5
|
const { payload } = this;
|
16
|
-
const migrationFiles = await
|
6
|
+
const migrationFiles = await readMigrationFiles({
|
17
7
|
payload
|
18
8
|
});
|
19
|
-
const { existingMigrations, latestBatch } = await
|
9
|
+
const { existingMigrations, latestBatch } = await getMigrations({
|
20
10
|
payload
|
21
11
|
});
|
22
12
|
if (!existingMigrations?.length) {
|
@@ -42,7 +32,7 @@ async function migrateDown() {
|
|
42
32
|
payload.logger.info({
|
43
33
|
msg: `Migrating down: ${migrationFile.name}`
|
44
34
|
});
|
45
|
-
await
|
35
|
+
await initTransaction(req);
|
46
36
|
await migrationFile.down({
|
47
37
|
payload,
|
48
38
|
req
|
@@ -50,7 +40,7 @@ async function migrateDown() {
|
|
50
40
|
payload.logger.info({
|
51
41
|
msg: `Migrated down: ${migrationFile.name} (${Date.now() - start}ms)`
|
52
42
|
});
|
53
|
-
const tableExists = await
|
43
|
+
const tableExists = await migrationTableExists(this.drizzle);
|
54
44
|
if (tableExists) {
|
55
45
|
await payload.delete({
|
56
46
|
id: migration.id,
|
@@ -58,16 +48,16 @@ async function migrateDown() {
|
|
58
48
|
req
|
59
49
|
});
|
60
50
|
}
|
61
|
-
await
|
51
|
+
await commitTransaction(req);
|
62
52
|
} catch (err) {
|
63
|
-
await
|
53
|
+
await killTransaction(req);
|
64
54
|
payload.logger.error({
|
65
55
|
err,
|
66
|
-
msg:
|
56
|
+
msg: parseError(err, `Error migrating down ${migrationFile.name}. Rolling back.`)
|
67
57
|
});
|
68
58
|
process.exit(1);
|
69
59
|
}
|
70
60
|
}
|
71
61
|
}
|
72
62
|
|
73
|
-
//# sourceMappingURL=data:application/json;base64,
|
63
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uL3NyYy9taWdyYXRlRG93bi50cyJdLCJzb3VyY2VzQ29udGVudCI6WyIvKiBlc2xpbnQtZGlzYWJsZSBuby1yZXN0cmljdGVkLXN5bnRheCwgbm8tYXdhaXQtaW4tbG9vcCAqL1xuaW1wb3J0IHR5cGUgeyBQYXlsb2FkUmVxdWVzdCB9IGZyb20gJ3BheWxvYWQvdHlwZXMnXG5cbmltcG9ydCB7XG4gIGNvbW1pdFRyYW5zYWN0aW9uLFxuICBnZXRNaWdyYXRpb25zLFxuICBpbml0VHJhbnNhY3Rpb24sXG4gIGtpbGxUcmFuc2FjdGlvbixcbiAgcmVhZE1pZ3JhdGlvbkZpbGVzLFxufSBmcm9tICdwYXlsb2FkL2RhdGFiYXNlJ1xuXG5pbXBvcnQgdHlwZSB7IFBvc3RncmVzQWRhcHRlciB9IGZyb20gJy4vdHlwZXMnXG5cbmltcG9ydCB7IG1pZ3JhdGlvblRhYmxlRXhpc3RzIH0gZnJvbSAnLi91dGlsaXRpZXMvbWlncmF0aW9uVGFibGVFeGlzdHMnXG5pbXBvcnQgeyBwYXJzZUVycm9yIH0gZnJvbSAnLi91dGlsaXRpZXMvcGFyc2VFcnJvcidcblxuZXhwb3J0IGFzeW5jIGZ1bmN0aW9uIG1pZ3JhdGVEb3duKHRoaXM6IFBvc3RncmVzQWRhcHRlcik6IFByb21pc2U8dm9pZD4ge1xuICBjb25zdCB7IHBheWxvYWQgfSA9IHRoaXNcbiAgY29uc3QgbWlncmF0aW9uRmlsZXMgPSBhd2FpdCByZWFkTWlncmF0aW9uRmlsZXMoeyBwYXlsb2FkIH0pXG5cbiAgY29uc3QgeyBleGlzdGluZ01pZ3JhdGlvbnMsIGxhdGVzdEJhdGNoIH0gPSBhd2FpdCBnZXRNaWdyYXRpb25zKHtcbiAgICBwYXlsb2FkLFxuICB9KVxuXG4gIGlmICghZXhpc3RpbmdNaWdyYXRpb25zPy5sZW5ndGgpIHtcbiAgICBwYXlsb2FkLmxvZ2dlci5pbmZvKHsgbXNnOiAnTm8gbWlncmF0aW9ucyB0byByb2xsYmFjay4nIH0pXG4gICAgcmV0dXJuXG4gIH1cblxuICBwYXlsb2FkLmxvZ2dlci5pbmZvKHtcbiAgICBtc2c6IGBSb2xsaW5nIGJhY2sgYmF0Y2ggJHtsYXRlc3RCYXRjaH0gY29uc2lzdGluZyBvZiAke2V4aXN0aW5nTWlncmF0aW9ucy5sZW5ndGh9IG1pZ3JhdGlvbihzKS5gLFxuICB9KVxuXG4gIGNvbnN0IGxhdGVzdEJhdGNoTWlncmF0aW9ucyA9IGV4aXN0aW5nTWlncmF0aW9ucy5maWx0ZXIoKHsgYmF0Y2ggfSkgPT4gYmF0Y2ggPT09IGxhdGVzdEJhdGNoKVxuXG4gIGZvciAoY29uc3QgbWlncmF0aW9uIG9mIGxhdGVzdEJhdGNoTWlncmF0aW9ucykge1xuICAgIGNvbnN0IG1pZ3JhdGlvbkZpbGUgPSBtaWdyYXRpb25GaWxlcy5maW5kKChtKSA9PiBtLm5hbWUgPT09IG1pZ3JhdGlvbi5uYW1lKVxuICAgIGlmICghbWlncmF0aW9uRmlsZSkge1xuICAgICAgdGhyb3cgbmV3IEVycm9yKGBNaWdyYXRpb24gJHttaWdyYXRpb24ubmFtZX0gbm90IGZvdW5kIGxvY2FsbHkuYClcbiAgICB9XG5cbiAgICBjb25zdCBzdGFydCA9IERhdGUubm93KClcbiAgICBjb25zdCByZXEgPSB7IHBheWxvYWQgfSBhcyBQYXlsb2FkUmVxdWVzdFxuXG4gICAgdHJ5IHtcbiAgICAgIHBheWxvYWQubG9nZ2VyLmluZm8oeyBtc2c6IGBNaWdyYXRpbmcgZG93bjogJHttaWdyYXRpb25GaWxlLm5hbWV9YCB9KVxuICAgICAgYXdhaXQgaW5pdFRyYW5zYWN0aW9uKHJlcSlcbiAgICAgIGF3YWl0IG1pZ3JhdGlvbkZpbGUuZG93bih7IHBheWxvYWQsIHJlcSB9KVxuICAgICAgcGF5bG9hZC5sb2dnZXIuaW5mbyh7XG4gICAgICAgIG1zZzogYE1pZ3JhdGVkIGRvd246ICAke21pZ3JhdGlvbkZpbGUubmFtZX0gKCR7RGF0ZS5ub3coKSAtIHN0YXJ0fW1zKWAsXG4gICAgICB9KVxuXG4gICAgICBjb25zdCB0YWJsZUV4aXN0cyA9IGF3YWl0IG1pZ3JhdGlvblRhYmxlRXhpc3RzKHRoaXMuZHJpenpsZSlcbiAgICAgIGlmICh0YWJsZUV4aXN0cykge1xuICAgICAgICBhd2FpdCBwYXlsb2FkLmRlbGV0ZSh7XG4gICAgICAgICAgaWQ6IG1pZ3JhdGlvbi5pZCxcbiAgICAgICAgICBjb2xsZWN0aW9uOiAncGF5bG9hZC1taWdyYXRpb25zJyxcbiAgICAgICAgICByZXEsXG4gICAgICAgIH0pXG4gICAgICB9XG5cbiAgICAgIGF3YWl0IGNvbW1pdFRyYW5zYWN0aW9uKHJlcSlcbiAgICB9IGNhdGNoIChlcnI6IHVua25vd24pIHtcbiAgICAgIGF3YWl0IGtpbGxUcmFuc2FjdGlvbihyZXEpXG5cbiAgICAgIHBheWxvYWQubG9nZ2VyLmVycm9yKHtcbiAgICAgICAgZXJyLFxuICAgICAgICBtc2c6IHBhcnNlRXJyb3IoZXJyLCBgRXJyb3IgbWlncmF0aW5nIGRvd24gJHttaWdyYXRpb25GaWxlLm5hbWV9LiBSb2xsaW5nIGJhY2suYCksXG4gICAgICB9KVxuICAgICAgcHJvY2Vzcy5leGl0KDEpXG4gICAgfVxuICB9XG59XG4iXSwibmFtZXMiOlsiY29tbWl0VHJhbnNhY3Rpb24iLCJnZXRNaWdyYXRpb25zIiwiaW5pdFRyYW5zYWN0aW9uIiwia2lsbFRyYW5zYWN0aW9uIiwicmVhZE1pZ3JhdGlvbkZpbGVzIiwibWlncmF0aW9uVGFibGVFeGlzdHMiLCJwYXJzZUVycm9yIiwibWlncmF0ZURvd24iLCJwYXlsb2FkIiwibWlncmF0aW9uRmlsZXMiLCJleGlzdGluZ01pZ3JhdGlvbnMiLCJsYXRlc3RCYXRjaCIsImxlbmd0aCIsImxvZ2dlciIsImluZm8iLCJtc2ciLCJsYXRlc3RCYXRjaE1pZ3JhdGlvbnMiLCJmaWx0ZXIiLCJiYXRjaCIsIm1pZ3JhdGlvbiIsIm1pZ3JhdGlvbkZpbGUiLCJmaW5kIiwibSIsIm5hbWUiLCJFcnJvciIsInN0YXJ0IiwiRGF0ZSIsIm5vdyIsInJlcSIsImRvd24iLCJ0YWJsZUV4aXN0cyIsImRyaXp6bGUiLCJkZWxldGUiLCJpZCIsImNvbGxlY3Rpb24iLCJlcnIiLCJlcnJv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
|