@payloadcms/db-mongodb 1.0.0-beta.5 → 1.0.0-beta.7

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/README.md ADDED
@@ -0,0 +1,28 @@
1
+ # Payload MongoDB Adapter
2
+
3
+ Official MongoDB adapter for [Payload](https://payloadcms.com).
4
+
5
+ - [Main Repository](https://github.com/payloadcms/payload)
6
+ - [Payload Docs](https://payloadcms.com/docs)
7
+
8
+ ## Installation
9
+
10
+ ```bash
11
+ npm install @payloadcms/db-mongodb
12
+ ```
13
+
14
+ ## Usage
15
+
16
+ ```ts
17
+ import { buildConfig } from 'payload/config'
18
+ import { mongooseAdapter } from '@payloadcms/db-mongodb'
19
+
20
+ export default buildConfig({
21
+ db: mongooseAdapter({}),
22
+ // ...rest of config
23
+ })
24
+
25
+ ```
26
+
27
+ More detailed usage can be found in the [Payload Docs](https://payloadcms.com/docs/configuration/overview).
28
+
@@ -0,0 +1,3 @@
1
+ import type { CreateMigration } from 'payload/database';
2
+ export declare const createMigration: CreateMigration;
3
+ //# sourceMappingURL=createMigration.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"createMigration.d.ts","sourceRoot":"","sources":["../src/createMigration.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,kBAAkB,CAAA;AAmBvD,eAAO,MAAM,eAAe,EAAE,eA2C7B,CAAA"}
@@ -0,0 +1,68 @@
1
+ /* eslint-disable no-restricted-syntax, no-await-in-loop */ "use strict";
2
+ Object.defineProperty(exports, "__esModule", {
3
+ value: true
4
+ });
5
+ Object.defineProperty(exports, "createMigration", {
6
+ enumerable: true,
7
+ get: function() {
8
+ return createMigration;
9
+ }
10
+ });
11
+ const _fs = /*#__PURE__*/ _interop_require_default(require("fs"));
12
+ const _path = /*#__PURE__*/ _interop_require_default(require("path"));
13
+ function _interop_require_default(obj) {
14
+ return obj && obj.__esModule ? obj : {
15
+ default: obj
16
+ };
17
+ }
18
+ const migrationTemplate = (upSQL, downSQL)=>`import {
19
+ MigrateUpArgs,
20
+ MigrateDownArgs,
21
+ } from "@payloadcms/db-mongodb";
22
+
23
+ export async function up({ payload }: MigrateUpArgs): Promise<void> {
24
+ ${upSQL ?? ` // Migration code`}
25
+ };
26
+
27
+ export async function down({ payload }: MigrateDownArgs): Promise<void> {
28
+ ${downSQL ?? ` // Migration code`}
29
+ };
30
+ `;
31
+ const createMigration = async function createMigration({ file, migrationName, payload }) {
32
+ const dir = payload.db.migrationDir;
33
+ if (!_fs.default.existsSync(dir)) {
34
+ _fs.default.mkdirSync(dir);
35
+ }
36
+ let migrationFileContent;
37
+ // Check for predefined migration
38
+ if (file) {
39
+ const predefinedMigrationName = file.replace('@payloadcms/db-mongodb/', '');
40
+ migrationName = predefinedMigrationName;
41
+ const cleanPath = _path.default.join(__dirname, `../predefinedMigrations/${predefinedMigrationName}.js`);
42
+ // Check if predefined migration exists
43
+ if (_fs.default.existsSync(cleanPath)) {
44
+ const { down, up } = require(cleanPath);
45
+ migrationFileContent = migrationTemplate(up, down);
46
+ } else {
47
+ payload.logger.error({
48
+ msg: `Canned migration ${predefinedMigrationName} not found.`
49
+ });
50
+ process.exit(1);
51
+ }
52
+ } else {
53
+ migrationFileContent = migrationTemplate();
54
+ }
55
+ const [yyymmdd, hhmmss] = new Date().toISOString().split('T');
56
+ const formattedDate = yyymmdd.replace(/\D/g, '');
57
+ const formattedTime = hhmmss.split('.')[0].replace(/\D/g, '');
58
+ const timestamp = `${formattedDate}_${formattedTime}`;
59
+ const formattedName = migrationName.replace(/\W/g, '_');
60
+ const fileName = `${timestamp}_${formattedName}.ts`;
61
+ const filePath = `${dir}/${fileName}`;
62
+ _fs.default.writeFileSync(filePath, migrationFileContent);
63
+ payload.logger.info({
64
+ msg: `Migration created at ${filePath}`
65
+ });
66
+ };
67
+
68
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uL3NyYy9jcmVhdGVNaWdyYXRpb24udHMiXSwic291cmNlc0NvbnRlbnQiOlsiLyogZXNsaW50LWRpc2FibGUgbm8tcmVzdHJpY3RlZC1zeW50YXgsIG5vLWF3YWl0LWluLWxvb3AgKi9cbmltcG9ydCB0eXBlIHsgQ3JlYXRlTWlncmF0aW9uIH0gZnJvbSAncGF5bG9hZC9kYXRhYmFzZSdcblxuaW1wb3J0IGZzIGZyb20gJ2ZzJ1xuaW1wb3J0IHBhdGggZnJvbSAncGF0aCdcblxuY29uc3QgbWlncmF0aW9uVGVtcGxhdGUgPSAodXBTUUw/OiBzdHJpbmcsIGRvd25TUUw/OiBzdHJpbmcpID0+IGBpbXBvcnQge1xuICBNaWdyYXRlVXBBcmdzLFxuICBNaWdyYXRlRG93bkFyZ3MsXG59IGZyb20gXCJAcGF5bG9hZGNtcy9kYi1tb25nb2RiXCI7XG5cbmV4cG9ydCBhc3luYyBmdW5jdGlvbiB1cCh7IHBheWxvYWQgfTogTWlncmF0ZVVwQXJncyk6IFByb21pc2U8dm9pZD4ge1xuJHt1cFNRTCA/PyBgICAvLyBNaWdyYXRpb24gY29kZWB9XG59O1xuXG5leHBvcnQgYXN5bmMgZnVuY3Rpb24gZG93bih7IHBheWxvYWQgfTogTWlncmF0ZURvd25BcmdzKTogUHJvbWlzZTx2b2lkPiB7XG4ke2Rvd25TUUwgPz8gYCAgLy8gTWlncmF0aW9uIGNvZGVgfVxufTtcbmBcblxuZXhwb3J0IGNvbnN0IGNyZWF0ZU1pZ3JhdGlvbjogQ3JlYXRlTWlncmF0aW9uID0gYXN5bmMgZnVuY3Rpb24gY3JlYXRlTWlncmF0aW9uKHtcbiAgZmlsZSxcbiAgbWlncmF0aW9uTmFtZSxcbiAgcGF5bG9hZCxcbn0pIHtcbiAgY29uc3QgZGlyID0gcGF5bG9hZC5kYi5taWdyYXRpb25EaXJcbiAgaWYgKCFmcy5leGlzdHNTeW5jKGRpcikpIHtcbiAgICBmcy5ta2RpclN5bmMoZGlyKVxuICB9XG5cbiAgbGV0IG1pZ3JhdGlvbkZpbGVDb250ZW50OiBzdHJpbmcgfCB1bmRlZmluZWRcblxuICAvLyBDaGVjayBmb3IgcHJlZGVmaW5lZCBtaWdyYXRpb25cbiAgaWYgKGZpbGUpIHtcbiAgICBjb25zdCBwcmVkZWZpbmVkTWlncmF0aW9uTmFtZSA9IGZpbGUucmVwbGFjZSgnQHBheWxvYWRjbXMvZGItbW9uZ29kYi8nLCAnJylcbiAgICBtaWdyYXRpb25OYW1lID0gcHJlZGVmaW5lZE1pZ3JhdGlvbk5hbWVcbiAgICBjb25zdCBjbGVhblBhdGggPSBwYXRoLmpvaW4oX19kaXJuYW1lLCBgLi4vcHJlZGVmaW5lZE1pZ3JhdGlvbnMvJHtwcmVkZWZpbmVkTWlncmF0aW9uTmFtZX0uanNgKVxuXG4gICAgLy8gQ2hlY2sgaWYgcHJlZGVmaW5lZCBtaWdyYXRpb24gZXhpc3RzXG4gICAgaWYgKGZzLmV4aXN0c1N5bmMoY2xlYW5QYXRoKSkge1xuICAgICAgY29uc3QgeyBkb3duLCB1cCB9ID0gcmVxdWlyZShjbGVhblBhdGgpXG4gICAgICBtaWdyYXRpb25GaWxlQ29udGVudCA9IG1pZ3JhdGlvblRlbXBsYXRlKHVwLCBkb3duKVxuICAgIH0gZWxzZSB7XG4gICAgICBwYXlsb2FkLmxvZ2dlci5lcnJvcih7XG4gICAgICAgIG1zZzogYENhbm5lZCBtaWdyYXRpb24gJHtwcmVkZWZpbmVkTWlncmF0aW9uTmFtZX0gbm90IGZvdW5kLmAsXG4gICAgICB9KVxuICAgICAgcHJvY2Vzcy5leGl0KDEpXG4gICAgfVxuICB9IGVsc2Uge1xuICAgIG1pZ3JhdGlvbkZpbGVDb250ZW50ID0gbWlncmF0aW9uVGVtcGxhdGUoKVxuICB9XG5cbiAgY29uc3QgW3l5eW1tZGQsIGhobW1zc10gPSBuZXcgRGF0ZSgpLnRvSVNPU3RyaW5nKCkuc3BsaXQoJ1QnKVxuICBjb25zdCBmb3JtYXR0ZWREYXRlID0geXl5bW1kZC5yZXBsYWNlKC9cXEQvZywgJycpXG4gIGNvbnN0IGZvcm1hdHRlZFRpbWUgPSBoaG1tc3Muc3BsaXQoJy4nKVswXS5yZXBsYWNlKC9cXEQvZywgJycpXG5cbiAgY29uc3QgdGltZXN0YW1wID0gYCR7Zm9ybWF0dGVkRGF0ZX1fJHtmb3JtYXR0ZWRUaW1lfWBcblxuICBjb25zdCBmb3JtYXR0ZWROYW1lID0gbWlncmF0aW9uTmFtZS5yZXBsYWNlKC9cXFcvZywgJ18nKVxuICBjb25zdCBmaWxlTmFtZSA9IGAke3RpbWVzdGFtcH1fJHtmb3JtYXR0ZWROYW1lfS50c2BcbiAgY29uc3QgZmlsZVBhdGggPSBgJHtkaXJ9LyR7ZmlsZU5hbWV9YFxuICBmcy53cml0ZUZpbGVTeW5jKGZpbGVQYXRoLCBtaWdyYXRpb25GaWxlQ29udGVudClcbiAgcGF5bG9hZC5sb2dnZXIuaW5mbyh7IG1zZzogYE1pZ3JhdGlvbiBjcmVhdGVkIGF0ICR7ZmlsZVBhdGh9YCB9KVxufVxuIl0sIm5hbWVzIjpbImNyZWF0ZU1pZ3JhdGlvbiIsIm1pZ3JhdGlvblRlbXBsYXRlIiwidXBTUUwiLCJkb3duU1FMIiwiZmlsZSIsIm1pZ3JhdGlvbk5hbWUiLCJwYXlsb2FkIiwiZGlyIiwiZGIiLCJtaWdyYXRpb25EaXIiLCJmcyIsImV4aXN0c1N5bmMiLCJta2RpclN5bmMiLCJtaWdyYXRpb25GaWxlQ29udGVudCIsInByZWRlZmluZWRNaWdyYXRpb25OYW1lIiwicmVwbGFjZSIsImNsZWFuUGF0aCIsInBhdGgiLCJqb2luIiwiX19kaXJuYW1lIiwiZG93biIsInVwIiwicmVxdWlyZSIsImxvZ2dlciIsImVycm9yIiwibXNnIiwicHJvY2VzcyIsImV4aXQiLCJ5eXltbWRkIiwiaGhtbXNzIiwiRGF0ZSIsInRvSVNPU3RyaW5nIiwic3BsaXQiLCJmb3JtYXR0ZWREYXRlIiwiZm9ybWF0dGVkVGltZSIsInRpbWVzdGFtcCIsImZvcm1hdHRlZE5hbWUiLCJmaWxlTmFtZSIsImZpbGVQYXRoIiwid3JpdGVGaWxlU3luYyIsImluZm8iXSwibWFwcGluZ3MiOiJBQUFBLHlEQUF5RDs7OzsrQkFvQjVDQTs7O2VBQUFBOzs7MkRBakJFOzZEQUNFOzs7Ozs7QUFFakIsTUFBTUMsb0JBQW9CLENBQUNDLE9BQWdCQyxVQUFxQixDQUFDOzs7Ozs7QUFNakUsRUFBRUQsU0FBUyxDQUFDLG1CQUFtQixDQUFDLENBQUM7Ozs7QUFJakMsRUFBRUMsV0FBVyxDQUFDLG1CQUFtQixDQUFDLENBQUM7O0FBRW5DLENBQUM7QUFFTSxNQUFNSCxrQkFBbUMsZUFBZUEsZ0JBQWdCLEVBQzdFSSxJQUFJLEVBQ0pDLGFBQWEsRUFDYkMsT0FBTyxFQUNSO0lBQ0MsTUFBTUMsTUFBTUQsUUFBUUUsRUFBRSxDQUFDQyxZQUFZO0lBQ25DLElBQUksQ0FBQ0MsV0FBRSxDQUFDQyxVQUFVLENBQUNKLE1BQU07UUFDdkJHLFdBQUUsQ0FBQ0UsU0FBUyxDQUFDTDtJQUNmO0lBRUEsSUFBSU07SUFFSixpQ0FBaUM7SUFDakMsSUFBSVQsTUFBTTtRQUNSLE1BQU1VLDBCQUEwQlYsS0FBS1csT0FBTyxDQUFDLDJCQUEyQjtRQUN4RVYsZ0JBQWdCUztRQUNoQixNQUFNRSxZQUFZQyxhQUFJLENBQUNDLElBQUksQ0FBQ0MsV0FBVyxDQUFDLHdCQUF3QixFQUFFTCx3QkFBd0IsR0FBRyxDQUFDO1FBRTlGLHVDQUF1QztRQUN2QyxJQUFJSixXQUFFLENBQUNDLFVBQVUsQ0FBQ0ssWUFBWTtZQUM1QixNQUFNLEVBQUVJLElBQUksRUFBRUMsRUFBRSxFQUFFLEdBQUdDLFFBQVFOO1lBQzdCSCx1QkFBdUJaLGtCQUFrQm9CLElBQUlEO1FBQy9DLE9BQU87WUFDTGQsUUFBUWlCLE1BQU0sQ0FBQ0MsS0FBSyxDQUFDO2dCQUNuQkMsS0FBSyxDQUFDLGlCQUFpQixFQUFFWCx3QkFBd0IsV0FBVyxDQUFDO1lBQy9EO1lBQ0FZLFFBQVFDLElBQUksQ0FBQztRQUNmO0lBQ0YsT0FBTztRQUNMZCx1QkFBdUJaO0lBQ3pCO0lBRUEsTUFBTSxDQUFDMkIsU0FBU0MsT0FBTyxHQUFHLElBQUlDLE9BQU9DLFdBQVcsR0FBR0MsS0FBSyxDQUFDO0lBQ3pELE1BQU1DLGdCQUFnQkwsUUFBUWIsT0FBTyxDQUFDLE9BQU87SUFDN0MsTUFBTW1CLGdCQUFnQkwsT0FBT0csS0FBSyxDQUFDLElBQUksQ0FBQyxFQUFFLENBQUNqQixPQUFPLENBQUMsT0FBTztJQUUxRCxNQUFNb0IsWUFBWSxDQUFDLEVBQUVGLGNBQWMsQ0FBQyxFQUFFQyxjQUFjLENBQUM7SUFFckQsTUFBTUUsZ0JBQWdCL0IsY0FBY1UsT0FBTyxDQUFDLE9BQU87SUFDbkQsTUFBTXNCLFdBQVcsQ0FBQyxFQUFFRixVQUFVLENBQUMsRUFBRUMsY0FBYyxHQUFHLENBQUM7SUFDbkQsTUFBTUUsV0FBVyxDQUFDLEVBQUUvQixJQUFJLENBQUMsRUFBRThCLFNBQVMsQ0FBQztJQUNyQzNCLFdBQUUsQ0FBQzZCLGFBQWEsQ0FBQ0QsVUFBVXpCO0lBQzNCUCxRQUFRaUIsTUFBTSxDQUFDaUIsSUFBSSxDQUFDO1FBQUVmLEtBQUssQ0FBQyxxQkFBcUIsRUFBRWEsU0FBUyxDQUFDO0lBQUM7QUFDaEUifQ==
package/dist/index.d.ts CHANGED
@@ -44,5 +44,5 @@ declare module 'payload' {
44
44
  };
45
45
  }
46
46
  }
47
- export declare function mongooseAdapter({ autoPluralization, connectOptions, migrationDir, url, }: Args): MongooseAdapterResult;
47
+ export declare function mongooseAdapter({ autoPluralization, connectOptions, migrationDir: migrationDirArg, url, }: Args): MongooseAdapterResult;
48
48
  //# sourceMappingURL=index.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,aAAa,EAAE,cAAc,EAAE,UAAU,EAAE,MAAM,UAAU,CAAA;AACzE,OAAO,KAAK,EAAE,OAAO,EAAE,MAAM,SAAS,CAAA;AACtC,OAAO,KAAK,EAAE,mBAAmB,EAAE,MAAM,kBAAkB,CAAA;AAM3D,YAAY,EAAE,eAAe,EAAE,aAAa,EAAE,MAAM,SAAS,CAAA;AAE7D,OAAO,KAAK,EAAE,eAAe,EAAE,WAAW,EAAE,MAAM,SAAS,CAAA;AA4B3D,MAAM,WAAW,IAAI;IACnB,uFAAuF;IACvF,iBAAiB,CAAC,EAAE,OAAO,CAAA;IAC3B,kCAAkC;IAClC,cAAc,CAAC,EAAE,cAAc,GAAG;QAChC,4FAA4F;QAC5F,QAAQ,CAAC,EAAE,OAAO,CAAA;KACnB,CAAA;IACD,YAAY,CAAC,EAAE,MAAM,CAAA;IACrB,qFAAqF;IACrF,GAAG,EAAE,KAAK,GAAG,MAAM,CAAA;CACpB;AAED,MAAM,MAAM,eAAe,GAAG,mBAAmB,GAC/C,IAAI,GAAG;IACL,WAAW,EAAE;QACX,CAAC,IAAI,EAAE,MAAM,GAAG,eAAe,CAAA;KAChC,CAAA;IACD,UAAU,EAAE,UAAU,CAAA;IACtB,OAAO,EAAE,WAAW,CAAA;IACpB,iBAAiB,EAAE,GAAG,CAAA;IACtB,QAAQ,EAAE,MAAM,CAAC,MAAM,GAAG,MAAM,EAAE,aAAa,CAAC,CAAA;IAChD,QAAQ,EAAE;QACR,CAAC,IAAI,EAAE,MAAM,GAAG,eAAe,CAAA;KAChC,CAAA;CACF,CAAA;AAEH,KAAK,qBAAqB,GAAG,CAAC,IAAI,EAAE;IAAE,OAAO,EAAE,OAAO,CAAA;CAAE,KAAK,eAAe,CAAA;AAE5E,OAAO,QAAQ,SAAS,CAAC;IACvB,UAAiB,eAAgB,SAAQ,IAAI;QAC3C,WAAW,EAAE;YACX,CAAC,IAAI,EAAE,MAAM,GAAG,eAAe,CAAA;SAChC,CAAA;QACD,UAAU,EAAE,UAAU,CAAA;QACtB,OAAO,EAAE,WAAW,CAAA;QACpB,iBAAiB,EAAE,GAAG,CAAA;QACtB,QAAQ,EAAE,MAAM,CAAC,MAAM,GAAG,MAAM,EAAE,aAAa,CAAC,CAAA;QAChD,QAAQ,EAAE;YACR,CAAC,IAAI,EAAE,MAAM,GAAG,eAAe,CAAA;SAChC,CAAA;KACF;CACF;AAED,wBAAgB,eAAe,CAAC,EAC9B,iBAAwB,EACxB,cAAc,EACd,YAAY,EACZ,GAAG,GACJ,EAAE,IAAI,GAAG,qBAAqB,CAiD9B"}
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,aAAa,EAAE,cAAc,EAAE,UAAU,EAAE,MAAM,UAAU,CAAA;AACzE,OAAO,KAAK,EAAE,OAAO,EAAE,MAAM,SAAS,CAAA;AACtC,OAAO,KAAK,EAAE,mBAAmB,EAAE,MAAM,kBAAkB,CAAA;AAM3D,YAAY,EAAE,eAAe,EAAE,aAAa,EAAE,MAAM,SAAS,CAAA;AAE7D,OAAO,KAAK,EAAE,eAAe,EAAE,WAAW,EAAE,MAAM,SAAS,CAAA;AA8B3D,MAAM,WAAW,IAAI;IACnB,uFAAuF;IACvF,iBAAiB,CAAC,EAAE,OAAO,CAAA;IAC3B,kCAAkC;IAClC,cAAc,CAAC,EAAE,cAAc,GAAG;QAChC,4FAA4F;QAC5F,QAAQ,CAAC,EAAE,OAAO,CAAA;KACnB,CAAA;IACD,YAAY,CAAC,EAAE,MAAM,CAAA;IACrB,qFAAqF;IACrF,GAAG,EAAE,KAAK,GAAG,MAAM,CAAA;CACpB;AAED,MAAM,MAAM,eAAe,GAAG,mBAAmB,GAC/C,IAAI,GAAG;IACL,WAAW,EAAE;QACX,CAAC,IAAI,EAAE,MAAM,GAAG,eAAe,CAAA;KAChC,CAAA;IACD,UAAU,EAAE,UAAU,CAAA;IACtB,OAAO,EAAE,WAAW,CAAA;IACpB,iBAAiB,EAAE,GAAG,CAAA;IACtB,QAAQ,EAAE,MAAM,CAAC,MAAM,GAAG,MAAM,EAAE,aAAa,CAAC,CAAA;IAChD,QAAQ,EAAE;QACR,CAAC,IAAI,EAAE,MAAM,GAAG,eAAe,CAAA;KAChC,CAAA;CACF,CAAA;AAEH,KAAK,qBAAqB,GAAG,CAAC,IAAI,EAAE;IAAE,OAAO,EAAE,OAAO,CAAA;CAAE,KAAK,eAAe,CAAA;AAE5E,OAAO,QAAQ,SAAS,CAAC;IACvB,UAAiB,eAAgB,SAAQ,IAAI;QAC3C,WAAW,EAAE;YACX,CAAC,IAAI,EAAE,MAAM,GAAG,eAAe,CAAA;SAChC,CAAA;QACD,UAAU,EAAE,UAAU,CAAA;QACtB,OAAO,EAAE,WAAW,CAAA;QACpB,iBAAiB,EAAE,GAAG,CAAA;QACtB,QAAQ,EAAE,MAAM,CAAC,MAAM,GAAG,MAAM,EAAE,aAAa,CAAC,CAAA;QAChD,QAAQ,EAAE;YACR,CAAC,IAAI,EAAE,MAAM,GAAG,eAAe,CAAA;SAChC,CAAA;KACF;CACF;AAED,wBAAgB,eAAe,CAAC,EAC9B,iBAAwB,EACxB,cAAc,EACd,YAAY,EAAE,eAAe,EAC7B,GAAG,GACJ,EAAE,IAAI,GAAG,qBAAqB,CAuD9B"}
package/dist/index.js CHANGED
@@ -9,11 +9,13 @@ Object.defineProperty(exports, "mongooseAdapter", {
9
9
  }
10
10
  });
11
11
  const _mongoose = /*#__PURE__*/ _interop_require_default(require("mongoose"));
12
+ const _path = /*#__PURE__*/ _interop_require_default(require("path"));
12
13
  const _database = require("payload/database");
13
14
  const _connect = require("./connect");
14
15
  const _create = require("./create");
15
16
  const _createGlobal = require("./createGlobal");
16
17
  const _createGlobalVersion = require("./createGlobalVersion");
18
+ const _createMigration = require("./createMigration");
17
19
  const _createVersion = require("./createVersion");
18
20
  const _deleteMany = require("./deleteMany");
19
21
  const _deleteOne = require("./deleteOne");
@@ -27,6 +29,7 @@ const _findGlobalVersions = require("./findGlobalVersions");
27
29
  const _findOne = require("./findOne");
28
30
  const _findVersions = require("./findVersions");
29
31
  const _init = require("./init");
32
+ const _migrateFresh = require("./migrateFresh");
30
33
  const _queryDrafts = require("./queryDrafts");
31
34
  const _beginTransaction = require("./transactions/beginTransaction");
32
35
  const _commitTransaction = require("./transactions/commitTransaction");
@@ -40,23 +43,32 @@ function _interop_require_default(obj) {
40
43
  default: obj
41
44
  };
42
45
  }
43
- function mongooseAdapter({ autoPluralization = true, connectOptions, migrationDir, url }) {
46
+ function mongooseAdapter({ autoPluralization = true, connectOptions, migrationDir: migrationDirArg, url }) {
44
47
  function adapter({ payload }) {
48
+ const migrationDir = migrationDirArg || _path.default.resolve(process.cwd(), 'src/migrations');
45
49
  _mongoose.default.set('strictQuery', false);
46
50
  (0, _extendWebpackConfig.extendWebpackConfig)(payload.config);
47
51
  (0, _extendViteConfig.extendViteConfig)(payload.config);
48
52
  return (0, _database.createDatabaseAdapter)({
53
+ name: 'mongoose',
54
+ // Mongoose-specific
49
55
  autoPluralization,
50
- beginTransaction: _beginTransaction.beginTransaction,
51
56
  collections: {},
52
- commitTransaction: _commitTransaction.commitTransaction,
53
- connect: _connect.connect,
54
57
  connectOptions: connectOptions || {},
55
58
  connection: undefined,
59
+ globals: undefined,
60
+ mongoMemoryServer: undefined,
61
+ sessions: {},
62
+ url,
63
+ versions: {},
64
+ // DatabaseAdapter
65
+ beginTransaction: _beginTransaction.beginTransaction,
66
+ commitTransaction: _commitTransaction.commitTransaction,
67
+ connect: _connect.connect,
56
68
  create: _create.create,
57
69
  createGlobal: _createGlobal.createGlobal,
58
70
  createGlobalVersion: _createGlobalVersion.createGlobalVersion,
59
- createMigration: _database.createMigration,
71
+ createMigration: _createMigration.createMigration,
60
72
  createVersion: _createVersion.createVersion,
61
73
  defaultIDType: 'text',
62
74
  deleteMany: _deleteMany.deleteMany,
@@ -68,26 +80,19 @@ function mongooseAdapter({ autoPluralization = true, connectOptions, migrationDi
68
80
  findGlobalVersions: _findGlobalVersions.findGlobalVersions,
69
81
  findOne: _findOne.findOne,
70
82
  findVersions: _findVersions.findVersions,
71
- globals: undefined,
72
83
  init: _init.init,
73
- ...migrationDir && {
74
- migrationDir
75
- },
76
- name: 'mongoose',
77
- mongoMemoryServer: undefined,
84
+ migrateFresh: _migrateFresh.migrateFresh,
85
+ migrationDir,
78
86
  payload,
79
87
  queryDrafts: _queryDrafts.queryDrafts,
80
88
  rollbackTransaction: _rollbackTransaction.rollbackTransaction,
81
- sessions: {},
82
89
  updateGlobal: _updateGlobal.updateGlobal,
83
90
  updateGlobalVersion: _updateGlobalVersion.updateGlobalVersion,
84
91
  updateOne: _updateOne.updateOne,
85
- updateVersion: _updateVersion.updateVersion,
86
- url,
87
- versions: {}
92
+ updateVersion: _updateVersion.updateVersion
88
93
  });
89
94
  }
90
95
  return adapter;
91
96
  }
92
97
 
93
- //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../src/index.ts"],"sourcesContent":["import type { ClientSession, ConnectOptions, Connection } from 'mongoose'\nimport type { Payload } from 'payload'\nimport type { BaseDatabaseAdapter } from 'payload/database'\n\nimport mongoose from 'mongoose'\nimport { createDatabaseAdapter } from 'payload/database'\nimport { createMigration } from 'payload/database'\n\nexport type { MigrateDownArgs, MigrateUpArgs } from './types'\n\nimport type { CollectionModel, GlobalModel } from './types'\n\nimport { connect } from './connect'\nimport { create } from './create'\nimport { createGlobal } from './createGlobal'\nimport { createGlobalVersion } from './createGlobalVersion'\nimport { createVersion } from './createVersion'\nimport { deleteMany } from './deleteMany'\nimport { deleteOne } from './deleteOne'\nimport { deleteVersions } from './deleteVersions'\nimport { destroy } from './destroy'\nimport { extendViteConfig } from './extendViteConfig'\nimport { extendWebpackConfig } from './extendWebpackConfig'\nimport { find } from './find'\nimport { findGlobal } from './findGlobal'\nimport { findGlobalVersions } from './findGlobalVersions'\nimport { findOne } from './findOne'\nimport { findVersions } from './findVersions'\nimport { init } from './init'\nimport { queryDrafts } from './queryDrafts'\nimport { beginTransaction } from './transactions/beginTransaction'\nimport { commitTransaction } from './transactions/commitTransaction'\nimport { rollbackTransaction } from './transactions/rollbackTransaction'\nimport { updateGlobal } from './updateGlobal'\nimport { updateGlobalVersion } from './updateGlobalVersion'\nimport { updateOne } from './updateOne'\nimport { updateVersion } from './updateVersion'\n\nexport interface Args {\n  /** Set to false to disable auto-pluralization of collection names, Defaults to true */\n  autoPluralization?: boolean\n  /** Extra configuration options */\n  connectOptions?: ConnectOptions & {\n    /** Set false to disable $facet aggregation in non-supporting databases, Defaults to true */\n    useFacet?: boolean\n  }\n  migrationDir?: string\n  /** The URL to connect to MongoDB or false to start payload and prevent connecting */\n  url: false | string\n}\n\nexport type MongooseAdapter = BaseDatabaseAdapter &\n  Args & {\n    collections: {\n      [slug: string]: CollectionModel\n    }\n    connection: Connection\n    globals: GlobalModel\n    mongoMemoryServer: any\n    sessions: Record<number | string, ClientSession>\n    versions: {\n      [slug: string]: CollectionModel\n    }\n  }\n\ntype MongooseAdapterResult = (args: { payload: Payload }) => MongooseAdapter\n\ndeclare module 'payload' {\n  export interface DatabaseAdapter extends Args {\n    collections: {\n      [slug: string]: CollectionModel\n    }\n    connection: Connection\n    globals: GlobalModel\n    mongoMemoryServer: any\n    sessions: Record<number | string, ClientSession>\n    versions: {\n      [slug: string]: CollectionModel\n    }\n  }\n}\n\nexport function mongooseAdapter({\n  autoPluralization = true,\n  connectOptions,\n  migrationDir,\n  url,\n}: Args): MongooseAdapterResult {\n  function adapter({ payload }: { payload: Payload }) {\n    mongoose.set('strictQuery', false)\n\n    extendWebpackConfig(payload.config)\n    extendViteConfig(payload.config)\n\n    return createDatabaseAdapter<MongooseAdapter>({\n      autoPluralization,\n      beginTransaction,\n      collections: {},\n      commitTransaction,\n      connect,\n      connectOptions: connectOptions || {},\n      connection: undefined,\n      create,\n      createGlobal,\n      createGlobalVersion,\n      createMigration,\n      createVersion,\n      defaultIDType: 'text',\n      deleteMany,\n      deleteOne,\n      deleteVersions,\n      destroy,\n      find,\n      findGlobal,\n      findGlobalVersions,\n      findOne,\n      findVersions,\n      globals: undefined,\n      init,\n      ...(migrationDir && { migrationDir }),\n      name: 'mongoose',\n      mongoMemoryServer: undefined,\n      payload,\n      queryDrafts,\n      rollbackTransaction,\n      sessions: {},\n      updateGlobal,\n      updateGlobalVersion,\n      updateOne,\n      updateVersion,\n      url,\n      versions: {},\n    })\n  }\n\n  return adapter\n}\n"],"names":["mongooseAdapter","autoPluralization","connectOptions","migrationDir","url","adapter","payload","mongoose","set","extendWebpackConfig","config","extendViteConfig","createDatabaseAdapter","beginTransaction","collections","commitTransaction","connect","connection","undefined","create","createGlobal","createGlobalVersion","createMigration","createVersion","defaultIDType","deleteMany","deleteOne","deleteVersions","destroy","find","findGlobal","findGlobalVersions","findOne","findVersions","globals","init","name","mongoMemoryServer","queryDrafts","rollbackTransaction","sessions","updateGlobal","updateGlobalVersion","updateOne","updateVersion","versions"],"mappings":";;;;+BAkFgBA;;;eAAAA;;;iEA9EK;0BACiB;yBAOd;wBACD;8BACM;qCACO;+BACN;4BACH;2BACD;gCACK;yBACP;kCACS;qCACG;sBACf;4BACM;oCACQ;yBACX;8BACK;sBACR;6BACO;kCACK;mCACC;qCACE;8BACP;qCACO;2BACV;+BACI;;;;;;AA8CvB,SAASA,gBAAgB,EAC9BC,oBAAoB,IAAI,EACxBC,cAAc,EACdC,YAAY,EACZC,GAAG,EACE;IACL,SAASC,QAAQ,EAAEC,OAAO,EAAwB;QAChDC,iBAAQ,CAACC,GAAG,CAAC,eAAe;QAE5BC,IAAAA,wCAAmB,EAACH,QAAQI,MAAM;QAClCC,IAAAA,kCAAgB,EAACL,QAAQI,MAAM;QAE/B,OAAOE,IAAAA,+BAAqB,EAAkB;YAC5CX;YACAY,kBAAAA,kCAAgB;YAChBC,aAAa,CAAC;YACdC,mBAAAA,oCAAiB;YACjBC,SAAAA,gBAAO;YACPd,gBAAgBA,kBAAkB,CAAC;YACnCe,YAAYC;YACZC,QAAAA,cAAM;YACNC,cAAAA,0BAAY;YACZC,qBAAAA,wCAAmB;YACnBC,iBAAAA,yBAAe;YACfC,eAAAA,4BAAa;YACbC,eAAe;YACfC,YAAAA,sBAAU;YACVC,WAAAA,oBAAS;YACTC,gBAAAA,8BAAc;YACdC,SAAAA,gBAAO;YACPC,MAAAA,UAAI;YACJC,YAAAA,sBAAU;YACVC,oBAAAA,sCAAkB;YAClBC,SAAAA,gBAAO;YACPC,cAAAA,0BAAY;YACZC,SAAShB;YACTiB,MAAAA,UAAI;YACJ,GAAIhC,gBAAgB;gBAAEA;YAAa,CAAC;YACpCiC,MAAM;YACNC,mBAAmBnB;YACnBZ;YACAgC,aAAAA,wBAAW;YACXC,qBAAAA,wCAAmB;YACnBC,UAAU,CAAC;YACXC,cAAAA,0BAAY;YACZC,qBAAAA,wCAAmB;YACnBC,WAAAA,oBAAS;YACTC,eAAAA,4BAAa;YACbxC;YACAyC,UAAU,CAAC;QACb;IACF;IAEA,OAAOxC;AACT"}
98
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../src/index.ts"],"sourcesContent":["import type { ClientSession, ConnectOptions, Connection } from 'mongoose'\nimport type { Payload } from 'payload'\nimport type { BaseDatabaseAdapter } from 'payload/database'\n\nimport mongoose from 'mongoose'\nimport path from 'path'\nimport { createDatabaseAdapter } from 'payload/database'\n\nexport type { MigrateDownArgs, MigrateUpArgs } from './types'\n\nimport type { CollectionModel, GlobalModel } from './types'\n\nimport { connect } from './connect'\nimport { create } from './create'\nimport { createGlobal } from './createGlobal'\nimport { createGlobalVersion } from './createGlobalVersion'\nimport { createMigration } from './createMigration'\nimport { createVersion } from './createVersion'\nimport { deleteMany } from './deleteMany'\nimport { deleteOne } from './deleteOne'\nimport { deleteVersions } from './deleteVersions'\nimport { destroy } from './destroy'\nimport { extendViteConfig } from './extendViteConfig'\nimport { extendWebpackConfig } from './extendWebpackConfig'\nimport { find } from './find'\nimport { findGlobal } from './findGlobal'\nimport { findGlobalVersions } from './findGlobalVersions'\nimport { findOne } from './findOne'\nimport { findVersions } from './findVersions'\nimport { init } from './init'\nimport { migrateFresh } from './migrateFresh'\nimport { queryDrafts } from './queryDrafts'\nimport { beginTransaction } from './transactions/beginTransaction'\nimport { commitTransaction } from './transactions/commitTransaction'\nimport { rollbackTransaction } from './transactions/rollbackTransaction'\nimport { updateGlobal } from './updateGlobal'\nimport { updateGlobalVersion } from './updateGlobalVersion'\nimport { updateOne } from './updateOne'\nimport { updateVersion } from './updateVersion'\n\nexport interface Args {\n  /** Set to false to disable auto-pluralization of collection names, Defaults to true */\n  autoPluralization?: boolean\n  /** Extra configuration options */\n  connectOptions?: ConnectOptions & {\n    /** Set false to disable $facet aggregation in non-supporting databases, Defaults to true */\n    useFacet?: boolean\n  }\n  migrationDir?: string\n  /** The URL to connect to MongoDB or false to start payload and prevent connecting */\n  url: false | string\n}\n\nexport type MongooseAdapter = BaseDatabaseAdapter &\n  Args & {\n    collections: {\n      [slug: string]: CollectionModel\n    }\n    connection: Connection\n    globals: GlobalModel\n    mongoMemoryServer: any\n    sessions: Record<number | string, ClientSession>\n    versions: {\n      [slug: string]: CollectionModel\n    }\n  }\n\ntype MongooseAdapterResult = (args: { payload: Payload }) => MongooseAdapter\n\ndeclare module 'payload' {\n  export interface DatabaseAdapter extends Args {\n    collections: {\n      [slug: string]: CollectionModel\n    }\n    connection: Connection\n    globals: GlobalModel\n    mongoMemoryServer: any\n    sessions: Record<number | string, ClientSession>\n    versions: {\n      [slug: string]: CollectionModel\n    }\n  }\n}\n\nexport function mongooseAdapter({\n  autoPluralization = true,\n  connectOptions,\n  migrationDir: migrationDirArg,\n  url,\n}: Args): MongooseAdapterResult {\n  function adapter({ payload }: { payload: Payload }) {\n    const migrationDir = migrationDirArg || path.resolve(process.cwd(), 'src/migrations')\n    mongoose.set('strictQuery', false)\n\n    extendWebpackConfig(payload.config)\n    extendViteConfig(payload.config)\n\n    return createDatabaseAdapter<MongooseAdapter>({\n      name: 'mongoose',\n\n      // Mongoose-specific\n      autoPluralization,\n      collections: {},\n      connectOptions: connectOptions || {},\n      connection: undefined,\n      globals: undefined,\n      mongoMemoryServer: undefined,\n      sessions: {},\n      url,\n      versions: {},\n\n      // DatabaseAdapter\n      beginTransaction,\n      commitTransaction,\n      connect,\n      create,\n      createGlobal,\n      createGlobalVersion,\n      createMigration,\n      createVersion,\n      defaultIDType: 'text',\n      deleteMany,\n      deleteOne,\n      deleteVersions,\n      destroy,\n      find,\n      findGlobal,\n      findGlobalVersions,\n      findOne,\n      findVersions,\n      init,\n      migrateFresh,\n      migrationDir,\n      payload,\n      queryDrafts,\n      rollbackTransaction,\n      updateGlobal,\n      updateGlobalVersion,\n      updateOne,\n      updateVersion,\n    })\n  }\n\n  return adapter\n}\n"],"names":["mongooseAdapter","autoPluralization","connectOptions","migrationDir","migrationDirArg","url","adapter","payload","path","resolve","process","cwd","mongoose","set","extendWebpackConfig","config","extendViteConfig","createDatabaseAdapter","name","collections","connection","undefined","globals","mongoMemoryServer","sessions","versions","beginTransaction","commitTransaction","connect","create","createGlobal","createGlobalVersion","createMigration","createVersion","defaultIDType","deleteMany","deleteOne","deleteVersions","destroy","find","findGlobal","findGlobalVersions","findOne","findVersions","init","migrateFresh","queryDrafts","rollbackTransaction","updateGlobal","updateGlobalVersion","updateOne","updateVersion"],"mappings":";;;;+BAoFgBA;;;eAAAA;;;iEAhFK;6DACJ;0BACqB;yBAMd;wBACD;8BACM;qCACO;iCACJ;+BACF;4BACH;2BACD;gCACK;yBACP;kCACS;qCACG;sBACf;4BACM;oCACQ;yBACX;8BACK;sBACR;8BACQ;6BACD;kCACK;mCACC;qCACE;8BACP;qCACO;2BACV;+BACI;;;;;;AA8CvB,SAASA,gBAAgB,EAC9BC,oBAAoB,IAAI,EACxBC,cAAc,EACdC,cAAcC,eAAe,EAC7BC,GAAG,EACE;IACL,SAASC,QAAQ,EAAEC,OAAO,EAAwB;QAChD,MAAMJ,eAAeC,mBAAmBI,aAAI,CAACC,OAAO,CAACC,QAAQC,GAAG,IAAI;QACpEC,iBAAQ,CAACC,GAAG,CAAC,eAAe;QAE5BC,IAAAA,wCAAmB,EAACP,QAAQQ,MAAM;QAClCC,IAAAA,kCAAgB,EAACT,QAAQQ,MAAM;QAE/B,OAAOE,IAAAA,+BAAqB,EAAkB;YAC5CC,MAAM;YAEN,oBAAoB;YACpBjB;YACAkB,aAAa,CAAC;YACdjB,gBAAgBA,kBAAkB,CAAC;YACnCkB,YAAYC;YACZC,SAASD;YACTE,mBAAmBF;YACnBG,UAAU,CAAC;YACXnB;YACAoB,UAAU,CAAC;YAEX,kBAAkB;YAClBC,kBAAAA,kCAAgB;YAChBC,mBAAAA,oCAAiB;YACjBC,SAAAA,gBAAO;YACPC,QAAAA,cAAM;YACNC,cAAAA,0BAAY;YACZC,qBAAAA,wCAAmB;YACnBC,iBAAAA,gCAAe;YACfC,eAAAA,4BAAa;YACbC,eAAe;YACfC,YAAAA,sBAAU;YACVC,WAAAA,oBAAS;YACTC,gBAAAA,8BAAc;YACdC,SAAAA,gBAAO;YACPC,MAAAA,UAAI;YACJC,YAAAA,sBAAU;YACVC,oBAAAA,sCAAkB;YAClBC,SAAAA,gBAAO;YACPC,cAAAA,0BAAY;YACZC,MAAAA,UAAI;YACJC,cAAAA,0BAAY;YACZ1C;YACAI;YACAuC,aAAAA,wBAAW;YACXC,qBAAAA,wCAAmB;YACnBC,cAAAA,0BAAY;YACZC,qBAAAA,wCAAmB;YACnBC,WAAAA,oBAAS;YACTC,eAAAA,4BAAa;QACf;IACF;IAEA,OAAO7C;AACT"}
@@ -0,0 +1,6 @@
1
+ import type { MongooseAdapter } from '.';
2
+ /**
3
+ * Drop the current database and run all migrate up functions
4
+ */
5
+ export declare function migrateFresh(this: MongooseAdapter): Promise<void>;
6
+ //# sourceMappingURL=migrateFresh.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"migrateFresh.d.ts","sourceRoot":"","sources":["../src/migrateFresh.ts"],"names":[],"mappings":"AAKA,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,GAAG,CAAA;AAExC;;GAEG;AACH,wBAAsB,YAAY,CAAC,IAAI,EAAE,eAAe,GAAG,OAAO,CAAC,IAAI,CAAC,CA8DvE"}
@@ -0,0 +1,80 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", {
3
+ value: true
4
+ });
5
+ Object.defineProperty(exports, "migrateFresh", {
6
+ enumerable: true,
7
+ get: function() {
8
+ return migrateFresh;
9
+ }
10
+ });
11
+ const _database = require("payload/database");
12
+ const _prompts = /*#__PURE__*/ _interop_require_default(require("prompts"));
13
+ function _interop_require_default(obj) {
14
+ return obj && obj.__esModule ? obj : {
15
+ default: obj
16
+ };
17
+ }
18
+ async function migrateFresh() {
19
+ const { payload } = this;
20
+ const { confirm: acceptWarning } = await (0, _prompts.default)({
21
+ name: 'confirm',
22
+ initial: false,
23
+ message: `WARNING: This will drop your database and run all migrations. Are you sure you want to proceed?`,
24
+ type: 'confirm'
25
+ }, {
26
+ onCancel: ()=>{
27
+ process.exit(0);
28
+ }
29
+ });
30
+ if (!acceptWarning) {
31
+ process.exit(0);
32
+ }
33
+ payload.logger.info({
34
+ msg: `Dropping database.`
35
+ });
36
+ await this.connection.dropDatabase();
37
+ const migrationFiles = await (0, _database.readMigrationFiles)({
38
+ payload
39
+ });
40
+ payload.logger.debug({
41
+ msg: `Found ${migrationFiles.length} migration files.`
42
+ });
43
+ let transactionID;
44
+ // Run all migrate up
45
+ for (const migration of migrationFiles){
46
+ payload.logger.info({
47
+ msg: `Migrating: ${migration.name}`
48
+ });
49
+ try {
50
+ const start = Date.now();
51
+ transactionID = await this.beginTransaction();
52
+ await migration.up({
53
+ payload
54
+ });
55
+ await payload.create({
56
+ collection: 'payload-migrations',
57
+ data: {
58
+ name: migration.name,
59
+ batch: 1
60
+ },
61
+ req: {
62
+ transactionID
63
+ }
64
+ });
65
+ await this.commitTransaction(transactionID);
66
+ payload.logger.info({
67
+ msg: `Migrated: ${migration.name} (${Date.now() - start}ms)`
68
+ });
69
+ } catch (err) {
70
+ await this.rollbackTransaction(transactionID);
71
+ payload.logger.error({
72
+ err,
73
+ msg: `Error running migration ${migration.name}. Rolling back.`
74
+ });
75
+ throw err;
76
+ }
77
+ }
78
+ }
79
+
80
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uL3NyYy9taWdyYXRlRnJlc2gudHMiXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHR5cGUgeyBQYXlsb2FkUmVxdWVzdCB9IGZyb20gJ3BheWxvYWQvdHlwZXMnXG5cbmltcG9ydCB7IHJlYWRNaWdyYXRpb25GaWxlcyB9IGZyb20gJ3BheWxvYWQvZGF0YWJhc2UnXG5pbXBvcnQgcHJvbXB0cyBmcm9tICdwcm9tcHRzJ1xuXG5pbXBvcnQgdHlwZSB7IE1vbmdvb3NlQWRhcHRlciB9IGZyb20gJy4nXG5cbi8qKlxuICogRHJvcCB0aGUgY3VycmVudCBkYXRhYmFzZSBhbmQgcnVuIGFsbCBtaWdyYXRlIHVwIGZ1bmN0aW9uc1xuICovXG5leHBvcnQgYXN5bmMgZnVuY3Rpb24gbWlncmF0ZUZyZXNoKHRoaXM6IE1vbmdvb3NlQWRhcHRlcik6IFByb21pc2U8dm9pZD4ge1xuICBjb25zdCB7IHBheWxvYWQgfSA9IHRoaXNcblxuICBjb25zdCB7IGNvbmZpcm06IGFjY2VwdFdhcm5pbmcgfSA9IGF3YWl0IHByb21wdHMoXG4gICAge1xuICAgICAgbmFtZTogJ2NvbmZpcm0nLFxuICAgICAgaW5pdGlhbDogZmFsc2UsXG4gICAgICBtZXNzYWdlOiBgV0FSTklORzogVGhpcyB3aWxsIGRyb3AgeW91ciBkYXRhYmFzZSBhbmQgcnVuIGFsbCBtaWdyYXRpb25zLiBBcmUgeW91IHN1cmUgeW91IHdhbnQgdG8gcHJvY2VlZD9gLFxuICAgICAgdHlwZTogJ2NvbmZpcm0nLFxuICAgIH0sXG4gICAge1xuICAgICAgb25DYW5jZWw6ICgpID0+IHtcbiAgICAgICAgcHJvY2Vzcy5leGl0KDApXG4gICAgICB9LFxuICAgIH0sXG4gIClcblxuICBpZiAoIWFjY2VwdFdhcm5pbmcpIHtcbiAgICBwcm9jZXNzLmV4aXQoMClcbiAgfVxuXG4gIHBheWxvYWQubG9nZ2VyLmluZm8oe1xuICAgIG1zZzogYERyb3BwaW5nIGRhdGFiYXNlLmAsXG4gIH0pXG5cbiAgYXdhaXQgdGhpcy5jb25uZWN0aW9uLmRyb3BEYXRhYmFzZSgpXG5cbiAgY29uc3QgbWlncmF0aW9uRmlsZXMgPSBhd2FpdCByZWFkTWlncmF0aW9uRmlsZXMoeyBwYXlsb2FkIH0pXG4gIHBheWxvYWQubG9nZ2VyLmRlYnVnKHtcbiAgICBtc2c6IGBGb3VuZCAke21pZ3JhdGlvbkZpbGVzLmxlbmd0aH0gbWlncmF0aW9uIGZpbGVzLmAsXG4gIH0pXG5cbiAgbGV0IHRyYW5zYWN0aW9uSURcbiAgLy8gUnVuIGFsbCBtaWdyYXRlIHVwXG4gIGZvciAoY29uc3QgbWlncmF0aW9uIG9mIG1pZ3JhdGlvbkZpbGVzKSB7XG4gICAgcGF5bG9hZC5sb2dnZXIuaW5mbyh7IG1zZzogYE1pZ3JhdGluZzogJHttaWdyYXRpb24ubmFtZX1gIH0pXG4gICAgdHJ5IHtcbiAgICAgIGNvbnN0IHN0YXJ0ID0gRGF0ZS5ub3coKVxuICAgICAgdHJhbnNhY3Rpb25JRCA9IGF3YWl0IHRoaXMuYmVnaW5UcmFuc2FjdGlvbigpXG4gICAgICBhd2FpdCBtaWdyYXRpb24udXAoeyBwYXlsb2FkIH0pXG4gICAgICBhd2FpdCBwYXlsb2FkLmNyZWF0ZSh7XG4gICAgICAgIGNvbGxlY3Rpb246ICdwYXlsb2FkLW1pZ3JhdGlvbnMnLFxuICAgICAgICBkYXRhOiB7XG4gICAgICAgICAgbmFtZTogbWlncmF0aW9uLm5hbWUsXG4gICAgICAgICAgYmF0Y2g6IDEsXG4gICAgICAgIH0sXG4gICAgICAgIHJlcToge1xuICAgICAgICAgIHRyYW5zYWN0aW9uSUQsXG4gICAgICAgIH0gYXMgUGF5bG9hZFJlcXVlc3QsXG4gICAgICB9KVxuICAgICAgYXdhaXQgdGhpcy5jb21taXRUcmFuc2FjdGlvbih0cmFuc2FjdGlvbklEKVxuXG4gICAgICBwYXlsb2FkLmxvZ2dlci5pbmZvKHsgbXNnOiBgTWlncmF0ZWQ6ICAke21pZ3JhdGlvbi5uYW1lfSAoJHtEYXRlLm5vdygpIC0gc3RhcnR9bXMpYCB9KVxuICAgIH0gY2F0Y2ggKGVycjogdW5rbm93bikge1xuICAgICAgYXdhaXQgdGhpcy5yb2xsYmFja1RyYW5zYWN0aW9uKHRyYW5zYWN0aW9uSUQpXG4gICAgICBwYXlsb2FkLmxvZ2dlci5lcnJvcih7XG4gICAgICAgIGVycixcbiAgICAgICAgbXNnOiBgRXJyb3IgcnVubmluZyBtaWdyYXRpb24gJHttaWdyYXRpb24ubmFtZX0uIFJvbGxpbmcgYmFjay5gLFxuICAgICAgfSlcbiAgICAgIHRocm93IGVyclxuICAgIH1cbiAgfVxufVxuIl0sIm5hbWVzIjpbIm1pZ3JhdGVGcmVzaCIsInBheWxvYWQiLCJjb25maXJtIiwiYWNjZXB0V2FybmluZyIsInByb21wdHMiLCJuYW1lIiwiaW5pdGlhbCIsIm1lc3NhZ2UiLCJ0eXBlIiwib25DYW5jZWwiLCJwcm9jZXNzIiwiZXhpdCIsImxvZ2dlciIsImluZm8iLCJtc2ciLCJjb25uZWN0aW9uIiwiZHJvcERhdGFiYXNlIiwibWlncmF0aW9uRmlsZXMiLCJyZWFkTWlncmF0aW9uRmlsZXMiLCJkZWJ1ZyIsImxlbmd0aCIsInRyYW5zYWN0aW9uSUQiLCJtaWdyYXRpb24iLCJzdGFydCIsIkRhdGUiLCJub3ciLCJiZWdpblRyYW5zYWN0aW9uIiwidXAiLCJjcmVhdGUiLCJjb2xsZWN0aW9uIiwiZGF0YSIsImJhdGNoIiwicmVxIiwiY29tbWl0VHJhbnNhY3Rpb24iLCJlcnIiLCJyb2xsYmFja1RyYW5zYWN0aW9uIiwiZXJyb3IiXSwibWFwcGluZ3MiOiI7Ozs7K0JBVXNCQTs7O2VBQUFBOzs7MEJBUmE7Z0VBQ2Y7Ozs7OztBQU9iLGVBQWVBO0lBQ3BCLE1BQU0sRUFBRUMsT0FBTyxFQUFFLEdBQUcsSUFBSTtJQUV4QixNQUFNLEVBQUVDLFNBQVNDLGFBQWEsRUFBRSxHQUFHLE1BQU1DLElBQUFBLGdCQUFPLEVBQzlDO1FBQ0VDLE1BQU07UUFDTkMsU0FBUztRQUNUQyxTQUFTLENBQUMsK0ZBQStGLENBQUM7UUFDMUdDLE1BQU07SUFDUixHQUNBO1FBQ0VDLFVBQVU7WUFDUkMsUUFBUUMsSUFBSSxDQUFDO1FBQ2Y7SUFDRjtJQUdGLElBQUksQ0FBQ1IsZUFBZTtRQUNsQk8sUUFBUUMsSUFBSSxDQUFDO0lBQ2Y7SUFFQVYsUUFBUVcsTUFBTSxDQUFDQyxJQUFJLENBQUM7UUFDbEJDLEtBQUssQ0FBQyxrQkFBa0IsQ0FBQztJQUMzQjtJQUVBLE1BQU0sSUFBSSxDQUFDQyxVQUFVLENBQUNDLFlBQVk7SUFFbEMsTUFBTUMsaUJBQWlCLE1BQU1DLElBQUFBLDRCQUFrQixFQUFDO1FBQUVqQjtJQUFRO0lBQzFEQSxRQUFRVyxNQUFNLENBQUNPLEtBQUssQ0FBQztRQUNuQkwsS0FBSyxDQUFDLE1BQU0sRUFBRUcsZUFBZUcsTUFBTSxDQUFDLGlCQUFpQixDQUFDO0lBQ3hEO0lBRUEsSUFBSUM7SUFDSixxQkFBcUI7SUFDckIsS0FBSyxNQUFNQyxhQUFhTCxlQUFnQjtRQUN0Q2hCLFFBQVFXLE1BQU0sQ0FBQ0MsSUFBSSxDQUFDO1lBQUVDLEtBQUssQ0FBQyxXQUFXLEVBQUVRLFVBQVVqQixJQUFJLENBQUMsQ0FBQztRQUFDO1FBQzFELElBQUk7WUFDRixNQUFNa0IsUUFBUUMsS0FBS0MsR0FBRztZQUN0QkosZ0JBQWdCLE1BQU0sSUFBSSxDQUFDSyxnQkFBZ0I7WUFDM0MsTUFBTUosVUFBVUssRUFBRSxDQUFDO2dCQUFFMUI7WUFBUTtZQUM3QixNQUFNQSxRQUFRMkIsTUFBTSxDQUFDO2dCQUNuQkMsWUFBWTtnQkFDWkMsTUFBTTtvQkFDSnpCLE1BQU1pQixVQUFVakIsSUFBSTtvQkFDcEIwQixPQUFPO2dCQUNUO2dCQUNBQyxLQUFLO29CQUNIWDtnQkFDRjtZQUNGO1lBQ0EsTUFBTSxJQUFJLENBQUNZLGlCQUFpQixDQUFDWjtZQUU3QnBCLFFBQVFXLE1BQU0sQ0FBQ0MsSUFBSSxDQUFDO2dCQUFFQyxLQUFLLENBQUMsV0FBVyxFQUFFUSxVQUFVakIsSUFBSSxDQUFDLEVBQUUsRUFBRW1CLEtBQUtDLEdBQUcsS0FBS0YsTUFBTSxHQUFHLENBQUM7WUFBQztRQUN0RixFQUFFLE9BQU9XLEtBQWM7WUFDckIsTUFBTSxJQUFJLENBQUNDLG1CQUFtQixDQUFDZDtZQUMvQnBCLFFBQVFXLE1BQU0sQ0FBQ3dCLEtBQUssQ0FBQztnQkFDbkJGO2dCQUNBcEIsS0FBSyxDQUFDLHdCQUF3QixFQUFFUSxVQUFVakIsSUFBSSxDQUFDLGVBQWUsQ0FBQztZQUNqRTtZQUNBLE1BQU02QjtRQUNSO0lBQ0Y7QUFDRiJ9
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@payloadcms/db-mongodb",
3
- "version": "1.0.0-beta.5",
3
+ "version": "1.0.0-beta.7",
4
4
  "description": "The officially supported MongoDB database adapter for Payload",
5
5
  "repository": "https://github.com/payloadcms/payload",
6
6
  "license": "MIT",
@@ -19,20 +19,22 @@
19
19
  "mongoose": "6.11.4",
20
20
  "mongoose-aggregate-paginate-v2": "1.0.6",
21
21
  "mongoose-paginate-v2": "1.7.22",
22
+ "prompts": "2.4.2",
22
23
  "uuid": "9.0.0"
23
24
  },
24
25
  "devDependencies": {
25
26
  "@types/mongoose-aggregate-paginate-v2": "1.0.9",
26
27
  "mongodb-memory-server": "8.13.0",
27
28
  "@payloadcms/eslint-config": "0.0.1",
28
- "payload": "2.0.0-beta.15"
29
+ "payload": "2.0.0-beta.30"
29
30
  },
30
31
  "publishConfig": {
31
32
  "registry": "https://registry.npmjs.org/"
32
33
  },
33
34
  "files": [
34
35
  "dist",
35
- "mock.js"
36
+ "mock.js",
37
+ "predefinedMigrations"
36
38
  ],
37
39
  "scripts": {
38
40
  "build": "pnpm build:swc && pnpm build:types",
@@ -0,0 +1,96 @@
1
+ module.exports.up = ` async function migrateCollectionDocs(slug: string, docsAtATime = 100) {
2
+ const VersionsModel = payload.db.versions[slug]
3
+ const remainingDocs = await VersionsModel.aggregate(
4
+ [
5
+ // Sort so that newest are first
6
+ {
7
+ $sort: {
8
+ updatedAt: -1,
9
+ },
10
+ },
11
+ // Group by parent ID
12
+ // take the $first of each
13
+ {
14
+ $group: {
15
+ _id: '$parent',
16
+ _versionID: { $first: '$_id' },
17
+ createdAt: { $first: '$createdAt' },
18
+ latest: { $first: '$latest' },
19
+ updatedAt: { $first: '$updatedAt' },
20
+ version: { $first: '$version' },
21
+ },
22
+ },
23
+ {
24
+ $match: {
25
+ latest: { $eq: null },
26
+ },
27
+ },
28
+ {
29
+ $limit: docsAtATime,
30
+ },
31
+ ],
32
+ {
33
+ allowDiskUse: true,
34
+ },
35
+ ).exec()
36
+
37
+ if (!remainingDocs || remainingDocs.length === 0) {
38
+ const newVersions = await VersionsModel.find({
39
+ latest: {
40
+ $eq: true,
41
+ },
42
+ })
43
+
44
+ if (newVersions?.length) {
45
+ payload.logger.info(
46
+ \`Migrated \${newVersions.length} documents in the "\${slug}" versions collection.\`,
47
+ )
48
+ }
49
+
50
+ return
51
+ }
52
+
53
+ const remainingDocIds = remainingDocs.map((doc) => doc._versionID)
54
+
55
+ await VersionsModel.updateMany(
56
+ {
57
+ _id: {
58
+ $in: remainingDocIds,
59
+ },
60
+ },
61
+ {
62
+ latest: true,
63
+ },
64
+ )
65
+
66
+ await migrateCollectionDocs(slug)
67
+ }
68
+
69
+ // For each collection
70
+ await Promise.all(
71
+ payload.config.collections.map(async ({ slug, versions }) => {
72
+ if (versions) {
73
+ return migrateCollectionDocs(slug)
74
+ }
75
+ }),
76
+ )
77
+
78
+ // For each global
79
+ await Promise.all(
80
+ payload.config.globals.map(async ({ slug, versions }) => {
81
+ if (versions) {
82
+ const VersionsModel = payload.db.versions[slug]
83
+
84
+ await VersionsModel.findOneAndUpdate(
85
+ {},
86
+ { latest: true },
87
+ {
88
+ sort: { updatedAt: -1 },
89
+ },
90
+ ).exec()
91
+
92
+ payload.logger.info(\`Migrated the "\${slug}" global.\`)
93
+ }
94
+ }),
95
+ )
96
+ `
package/src/index.ts CHANGED
@@ -3,8 +3,8 @@ import type { Payload } from 'payload'
3
3
  import type { BaseDatabaseAdapter } from 'payload/database'
4
4
 
5
5
  import mongoose from 'mongoose'
6
+ import path from 'path'
6
7
  import { createDatabaseAdapter } from 'payload/database'
7
- import { createMigration } from 'payload/database'
8
8
 
9
9
  export type { MigrateDownArgs, MigrateUpArgs } from './types'
10
10
 
@@ -14,6 +14,7 @@ import { connect } from './connect'
14
14
  import { create } from './create'
15
15
  import { createGlobal } from './createGlobal'
16
16
  import { createGlobalVersion } from './createGlobalVersion'
17
+ import { createMigration } from './createMigration'
17
18
  import { createVersion } from './createVersion'
18
19
  import { deleteMany } from './deleteMany'
19
20
  import { deleteOne } from './deleteOne'
@@ -27,6 +28,7 @@ import { findGlobalVersions } from './findGlobalVersions'
27
28
  import { findOne } from './findOne'
28
29
  import { findVersions } from './findVersions'
29
30
  import { init } from './init'
31
+ import { migrateFresh } from './migrateFresh'
30
32
  import { queryDrafts } from './queryDrafts'
31
33
  import { beginTransaction } from './transactions/beginTransaction'
32
34
  import { commitTransaction } from './transactions/commitTransaction'
@@ -83,23 +85,34 @@ declare module 'payload' {
83
85
  export function mongooseAdapter({
84
86
  autoPluralization = true,
85
87
  connectOptions,
86
- migrationDir,
88
+ migrationDir: migrationDirArg,
87
89
  url,
88
90
  }: Args): MongooseAdapterResult {
89
91
  function adapter({ payload }: { payload: Payload }) {
92
+ const migrationDir = migrationDirArg || path.resolve(process.cwd(), 'src/migrations')
90
93
  mongoose.set('strictQuery', false)
91
94
 
92
95
  extendWebpackConfig(payload.config)
93
96
  extendViteConfig(payload.config)
94
97
 
95
98
  return createDatabaseAdapter<MongooseAdapter>({
99
+ name: 'mongoose',
100
+
101
+ // Mongoose-specific
96
102
  autoPluralization,
97
- beginTransaction,
98
103
  collections: {},
99
- commitTransaction,
100
- connect,
101
104
  connectOptions: connectOptions || {},
102
105
  connection: undefined,
106
+ globals: undefined,
107
+ mongoMemoryServer: undefined,
108
+ sessions: {},
109
+ url,
110
+ versions: {},
111
+
112
+ // DatabaseAdapter
113
+ beginTransaction,
114
+ commitTransaction,
115
+ connect,
103
116
  create,
104
117
  createGlobal,
105
118
  createGlobalVersion,
@@ -115,21 +128,16 @@ export function mongooseAdapter({
115
128
  findGlobalVersions,
116
129
  findOne,
117
130
  findVersions,
118
- globals: undefined,
119
131
  init,
120
- ...(migrationDir && { migrationDir }),
121
- name: 'mongoose',
122
- mongoMemoryServer: undefined,
132
+ migrateFresh,
133
+ migrationDir,
123
134
  payload,
124
135
  queryDrafts,
125
136
  rollbackTransaction,
126
- sessions: {},
127
137
  updateGlobal,
128
138
  updateGlobalVersion,
129
139
  updateOne,
130
140
  updateVersion,
131
- url,
132
- versions: {},
133
141
  })
134
142
  }
135
143