@payloadcms/db-mongodb 1.0.0-beta.6 → 1.0.0-beta.8
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 +28 -0
- package/dist/createMigration.d.ts +3 -0
- package/dist/createMigration.d.ts.map +1 -0
- package/dist/createMigration.js +68 -0
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +3 -2
- package/package.json +4 -3
- package/predefinedMigrations/versions-v1-v2.js +96 -0
- package/src/index.ts +1 -1
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 @@
|
|
|
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.map
CHANGED
|
@@ -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;
|
|
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
|
@@ -15,6 +15,7 @@ const _connect = require("./connect");
|
|
|
15
15
|
const _create = require("./create");
|
|
16
16
|
const _createGlobal = require("./createGlobal");
|
|
17
17
|
const _createGlobalVersion = require("./createGlobalVersion");
|
|
18
|
+
const _createMigration = require("./createMigration");
|
|
18
19
|
const _createVersion = require("./createVersion");
|
|
19
20
|
const _deleteMany = require("./deleteMany");
|
|
20
21
|
const _deleteOne = require("./deleteOne");
|
|
@@ -67,7 +68,7 @@ function mongooseAdapter({ autoPluralization = true, connectOptions, migrationDi
|
|
|
67
68
|
create: _create.create,
|
|
68
69
|
createGlobal: _createGlobal.createGlobal,
|
|
69
70
|
createGlobalVersion: _createGlobalVersion.createGlobalVersion,
|
|
70
|
-
createMigration:
|
|
71
|
+
createMigration: _createMigration.createMigration,
|
|
71
72
|
createVersion: _createVersion.createVersion,
|
|
72
73
|
defaultIDType: 'text',
|
|
73
74
|
deleteMany: _deleteMany.deleteMany,
|
|
@@ -94,4 +95,4 @@ function mongooseAdapter({ autoPluralization = true, connectOptions, migrationDi
|
|
|
94
95
|
return adapter;
|
|
95
96
|
}
|
|
96
97
|
|
|
97
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
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"}
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@payloadcms/db-mongodb",
|
|
3
|
-
"version": "1.0.0-beta.
|
|
3
|
+
"version": "1.0.0-beta.8",
|
|
4
4
|
"description": "The officially supported MongoDB database adapter for Payload",
|
|
5
5
|
"repository": "https://github.com/payloadcms/payload",
|
|
6
6
|
"license": "MIT",
|
|
@@ -26,14 +26,15 @@
|
|
|
26
26
|
"@types/mongoose-aggregate-paginate-v2": "1.0.9",
|
|
27
27
|
"mongodb-memory-server": "8.13.0",
|
|
28
28
|
"@payloadcms/eslint-config": "0.0.1",
|
|
29
|
-
"payload": "2.0.0-beta.
|
|
29
|
+
"payload": "2.0.0-beta.30"
|
|
30
30
|
},
|
|
31
31
|
"publishConfig": {
|
|
32
32
|
"registry": "https://registry.npmjs.org/"
|
|
33
33
|
},
|
|
34
34
|
"files": [
|
|
35
35
|
"dist",
|
|
36
|
-
"mock.js"
|
|
36
|
+
"mock.js",
|
|
37
|
+
"predefinedMigrations"
|
|
37
38
|
],
|
|
38
39
|
"scripts": {
|
|
39
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?.drafts) {
|
|
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
|
@@ -5,7 +5,6 @@ import type { BaseDatabaseAdapter } from 'payload/database'
|
|
|
5
5
|
import mongoose from 'mongoose'
|
|
6
6
|
import path from 'path'
|
|
7
7
|
import { createDatabaseAdapter } from 'payload/database'
|
|
8
|
-
import { createMigration } from 'payload/database'
|
|
9
8
|
|
|
10
9
|
export type { MigrateDownArgs, MigrateUpArgs } from './types'
|
|
11
10
|
|
|
@@ -15,6 +14,7 @@ import { connect } from './connect'
|
|
|
15
14
|
import { create } from './create'
|
|
16
15
|
import { createGlobal } from './createGlobal'
|
|
17
16
|
import { createGlobalVersion } from './createGlobalVersion'
|
|
17
|
+
import { createMigration } from './createMigration'
|
|
18
18
|
import { createVersion } from './createVersion'
|
|
19
19
|
import { deleteMany } from './deleteMany'
|
|
20
20
|
import { deleteOne } from './deleteOne'
|