@payloadcms/db-mongodb 1.3.2 → 1.4.1

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.
@@ -1 +1 @@
1
- {"version":3,"file":"connect.d.ts","sourceRoot":"","sources":["../src/connect.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,OAAO,EAAE,MAAM,kBAAkB,CAAA;AAM/C,eAAO,MAAM,OAAO,EAAE,OA2DrB,CAAA"}
1
+ {"version":3,"file":"connect.d.ts","sourceRoot":"","sources":["../src/connect.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,OAAO,EAAE,MAAM,kBAAkB,CAAA;AAM/C,eAAO,MAAM,OAAO,EAAE,OA8DrB,CAAA"}
package/dist/connect.js CHANGED
@@ -33,13 +33,16 @@ const connect = async function connect(payload) {
33
33
  urlToConnect = process.env.PAYLOAD_TEST_MONGO_URL;
34
34
  } else {
35
35
  connectionOptions.dbName = 'payloadmemory';
36
- const { MongoMemoryServer } = require('mongodb-memory-server');
36
+ const { MongoMemoryReplSet } = require('mongodb-memory-server');
37
37
  const getPort = require('get-port');
38
38
  const port = await getPort();
39
- this.mongoMemoryServer = await MongoMemoryServer.create({
39
+ this.mongoMemoryServer = await MongoMemoryReplSet.create({
40
40
  instance: {
41
41
  dbName: 'payloadmemory',
42
42
  port
43
+ },
44
+ replSet: {
45
+ count: 3
43
46
  }
44
47
  });
45
48
  urlToConnect = this.mongoMemoryServer.getUri();
@@ -65,4 +68,4 @@ const connect = async function connect(payload) {
65
68
  }
66
69
  };
67
70
 
68
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uL3NyYy9jb25uZWN0LnRzIl0sInNvdXJjZXNDb250ZW50IjpbIi8qIGVzbGludC1kaXNhYmxlIEB0eXBlc2NyaXB0LWVzbGludC9uby12YXItcmVxdWlyZXMgKi9cbmltcG9ydCB0eXBlIHsgQ29ubmVjdE9wdGlvbnMgfSBmcm9tICdtb25nb29zZSdcbmltcG9ydCB0eXBlIHsgQ29ubmVjdCB9IGZyb20gJ3BheWxvYWQvZGF0YWJhc2UnXG5cbmltcG9ydCBtb25nb29zZSBmcm9tICdtb25nb29zZSdcblxuaW1wb3J0IHR5cGUgeyBNb25nb29zZUFkYXB0ZXIgfSBmcm9tICcuJ1xuXG5leHBvcnQgY29uc3QgY29ubmVjdDogQ29ubmVjdCA9IGFzeW5jIGZ1bmN0aW9uIGNvbm5lY3QodGhpczogTW9uZ29vc2VBZGFwdGVyLCBwYXlsb2FkKSB7XG4gIGlmICh0aGlzLnVybCA9PT0gZmFsc2UpIHtcbiAgICByZXR1cm5cbiAgfVxuXG4gIGlmICghcGF5bG9hZC5sb2NhbCAmJiB0eXBlb2YgdGhpcy51cmwgIT09ICdzdHJpbmcnKSB7XG4gICAgdGhyb3cgbmV3IEVycm9yKCdFcnJvcjogbWlzc2luZyBNb25nb0RCIGNvbm5lY3Rpb24gVVJMLicpXG4gIH1cblxuICBsZXQgdXJsVG9Db25uZWN0ID0gdGhpcy51cmxcbiAgbGV0IHN1Y2Nlc3NmdWxDb25uZWN0aW9uTWVzc2FnZSA9ICdDb25uZWN0ZWQgdG8gTW9uZ29EQiBzZXJ2ZXIgc3VjY2Vzc2Z1bGx5ISdcblxuICBjb25zdCBjb25uZWN0aW9uT3B0aW9uczogQ29ubmVjdE9wdGlvbnMgJiB7IHVzZUZhY2V0OiB1bmRlZmluZWQgfSA9IHtcbiAgICBhdXRvSW5kZXg6IHRydWUsXG4gICAgLi4udGhpcy5jb25uZWN0T3B0aW9ucyxcbiAgICB1c2VGYWNldDogdW5kZWZpbmVkLFxuICB9XG5cbiAgaWYgKHByb2Nlc3MuZW52Lk5PREVfRU5WID09PSAndGVzdCcpIHtcbiAgICBpZiAocHJvY2Vzcy5lbnYuUEFZTE9BRF9URVNUX01PTkdPX1VSTCkge1xuICAgICAgdXJsVG9Db25uZWN0ID0gcHJvY2Vzcy5lbnYuUEFZTE9BRF9URVNUX01PTkdPX1VSTFxuICAgIH0gZWxzZSB7XG4gICAgICBjb25uZWN0aW9uT3B0aW9ucy5kYk5hbWUgPSAncGF5bG9hZG1lbW9yeSdcbiAgICAgIGNvbnN0IHsgTW9uZ29NZW1vcnlTZXJ2ZXIgfSA9IHJlcXVpcmUoJ21vbmdvZGItbWVtb3J5LXNlcnZlcicpXG4gICAgICBjb25zdCBnZXRQb3J0ID0gcmVxdWlyZSgnZ2V0LXBvcnQnKVxuXG4gICAgICBjb25zdCBwb3J0ID0gYXdhaXQgZ2V0UG9ydCgpXG4gICAgICB0aGlzLm1vbmdvTWVtb3J5U2VydmVyID0gYXdhaXQgTW9uZ29NZW1vcnlTZXJ2ZXIuY3JlYXRlKHtcbiAgICAgICAgaW5zdGFuY2U6IHtcbiAgICAgICAgICBkYk5hbWU6ICdwYXlsb2FkbWVtb3J5JyxcbiAgICAgICAgICBwb3J0LFxuICAgICAgICB9LFxuICAgICAgfSlcblxuICAgICAgdXJsVG9Db25uZWN0ID0gdGhpcy5tb25nb01lbW9yeVNlcnZlci5nZXRVcmkoKVxuICAgICAgc3VjY2Vzc2Z1bENvbm5lY3Rpb25NZXNzYWdlID0gJ0Nvbm5lY3RlZCB0byBpbi1tZW1vcnkgTW9uZ29EQiBzZXJ2ZXIgc3VjY2Vzc2Z1bGx5ISdcbiAgICB9XG4gIH1cblxuICB0cnkge1xuICAgIHRoaXMuY29ubmVjdGlvbiA9IChhd2FpdCBtb25nb29zZS5jb25uZWN0KHVybFRvQ29ubmVjdCwgY29ubmVjdGlvbk9wdGlvbnMpKS5jb25uZWN0aW9uXG5cbiAgICBjb25zdCBjbGllbnQgPSB0aGlzLmNvbm5lY3Rpb24uZ2V0Q2xpZW50KClcblxuICAgIGlmICghY2xpZW50Lm9wdGlvbnMucmVwbGljYVNldCkge1xuICAgICAgdGhpcy50cmFuc2FjdGlvbk9wdGlvbnMgPSBmYWxzZVxuICAgICAgdGhpcy5iZWdpblRyYW5zYWN0aW9uID0gdW5kZWZpbmVkXG4gICAgfVxuXG4gICAgaWYgKHByb2Nlc3MuZW52LlBBWUxPQURfRFJPUF9EQVRBQkFTRSA9PT0gJ3RydWUnKSB7XG4gICAgICB0aGlzLnBheWxvYWQubG9nZ2VyLmluZm8oJy0tLS0gRFJPUFBJTkcgREFUQUJBU0UgLS0tLScpXG4gICAgICBhd2FpdCBtb25nb29zZS5jb25uZWN0aW9uLmRyb3BEYXRhYmFzZSgpXG4gICAgICB0aGlzLnBheWxvYWQubG9nZ2VyLmluZm8oJy0tLS0gRFJPUFBFRCBEQVRBQkFTRSAtLS0tJylcbiAgICB9XG4gICAgdGhpcy5wYXlsb2FkLmxvZ2dlci5pbmZvKHN1Y2Nlc3NmdWxDb25uZWN0aW9uTWVzc2FnZSlcbiAgfSBjYXRjaCAoZXJyKSB7XG4gICAgdGhpcy5wYXlsb2FkLmxvZ2dlci5lcnJvcihgRXJyb3I6IGNhbm5vdCBjb25uZWN0IHRvIE1vbmdvREIuIERldGFpbHM6ICR7ZXJyLm1lc3NhZ2V9YCwgZXJyKVxuICAgIHByb2Nlc3MuZXhpdCgxKVxuICB9XG59XG4iXSwibmFtZXMiOlsiY29ubmVjdCIsInBheWxvYWQiLCJ1cmwiLCJsb2NhbCIsIkVycm9yIiwidXJsVG9Db25uZWN0Iiwic3VjY2Vzc2Z1bENvbm5lY3Rpb25NZXNzYWdlIiwiY29ubmVjdGlvbk9wdGlvbnMiLCJhdXRvSW5kZXgiLCJjb25uZWN0T3B0aW9ucyIsInVzZUZhY2V0IiwidW5kZWZpbmVkIiwicHJvY2VzcyIsImVudiIsIk5PREVfRU5WIiwiUEFZTE9BRF9URVNUX01PTkdPX1VSTCIsImRiTmFtZSIsIk1vbmdvTWVtb3J5U2VydmVyIiwicmVxdWlyZSIsImdldFBvcnQiLCJwb3J0IiwibW9uZ29NZW1vcnlTZXJ2ZXIiLCJjcmVhdGUiLCJpbnN0YW5jZSIsImdldFVyaSIsImNvbm5lY3Rpb24iLCJtb25nb29zZSIsImNsaWVudCIsImdldENsaWVudCIsIm9wdGlvbnMiLCJyZXBsaWNhU2V0IiwidHJhbnNhY3Rpb25PcHRpb25zIiwiYmVnaW5UcmFuc2FjdGlvbiIsIlBBWUxPQURfRFJPUF9EQVRBQkFTRSIsImxvZ2dlciIsImluZm8iLCJkcm9wRGF0YWJhc2UiLCJlcnIiLCJlcnJvciIsIm1lc3NhZ2UiLCJleGl0Il0sIm1hcHBpbmdzIjoiQUFBQSxxREFBcUQ7Ozs7K0JBUXhDQTs7O2VBQUFBOzs7aUVBSlE7Ozs7OztBQUlkLE1BQU1BLFVBQW1CLGVBQWVBLFFBQStCQyxPQUFPO0lBQ25GLElBQUksSUFBSSxDQUFDQyxHQUFHLEtBQUssT0FBTztRQUN0QjtJQUNGO0lBRUEsSUFBSSxDQUFDRCxRQUFRRSxLQUFLLElBQUksT0FBTyxJQUFJLENBQUNELEdBQUcsS0FBSyxVQUFVO1FBQ2xELE1BQU0sSUFBSUUsTUFBTTtJQUNsQjtJQUVBLElBQUlDLGVBQWUsSUFBSSxDQUFDSCxHQUFHO0lBQzNCLElBQUlJLDhCQUE4QjtJQUVsQyxNQUFNQyxvQkFBOEQ7UUFDbEVDLFdBQVc7UUFDWCxHQUFHLElBQUksQ0FBQ0MsY0FBYztRQUN0QkMsVUFBVUM7SUFDWjtJQUVBLElBQUlDLFFBQVFDLEdBQUcsQ0FBQ0MsUUFBUSxLQUFLLFFBQVE7UUFDbkMsSUFBSUYsUUFBUUMsR0FBRyxDQUFDRSxzQkFBc0IsRUFBRTtZQUN0Q1YsZUFBZU8sUUFBUUMsR0FBRyxDQUFDRSxzQkFBc0I7UUFDbkQsT0FBTztZQUNMUixrQkFBa0JTLE1BQU0sR0FBRztZQUMzQixNQUFNLEVBQUVDLGlCQUFpQixFQUFFLEdBQUdDLFFBQVE7WUFDdEMsTUFBTUMsVUFBVUQsUUFBUTtZQUV4QixNQUFNRSxPQUFPLE1BQU1EO1lBQ25CLElBQUksQ0FBQ0UsaUJBQWlCLEdBQUcsTUFBTUosa0JBQWtCSyxNQUFNLENBQUM7Z0JBQ3REQyxVQUFVO29CQUNSUCxRQUFRO29CQUNSSTtnQkFDRjtZQUNGO1lBRUFmLGVBQWUsSUFBSSxDQUFDZ0IsaUJBQWlCLENBQUNHLE1BQU07WUFDNUNsQiw4QkFBOEI7UUFDaEM7SUFDRjtJQUVBLElBQUk7UUFDRixJQUFJLENBQUNtQixVQUFVLEdBQUcsQUFBQyxDQUFBLE1BQU1DLGlCQUFRLENBQUMxQixPQUFPLENBQUNLLGNBQWNFLGtCQUFpQixFQUFHa0IsVUFBVTtRQUV0RixNQUFNRSxTQUFTLElBQUksQ0FBQ0YsVUFBVSxDQUFDRyxTQUFTO1FBRXhDLElBQUksQ0FBQ0QsT0FBT0UsT0FBTyxDQUFDQyxVQUFVLEVBQUU7WUFDOUIsSUFBSSxDQUFDQyxrQkFBa0IsR0FBRztZQUMxQixJQUFJLENBQUNDLGdCQUFnQixHQUFHckI7UUFDMUI7UUFFQSxJQUFJQyxRQUFRQyxHQUFHLENBQUNvQixxQkFBcUIsS0FBSyxRQUFRO1lBQ2hELElBQUksQ0FBQ2hDLE9BQU8sQ0FBQ2lDLE1BQU0sQ0FBQ0MsSUFBSSxDQUFDO1lBQ3pCLE1BQU1ULGlCQUFRLENBQUNELFVBQVUsQ0FBQ1csWUFBWTtZQUN0QyxJQUFJLENBQUNuQyxPQUFPLENBQUNpQyxNQUFNLENBQUNDLElBQUksQ0FBQztRQUMzQjtRQUNBLElBQUksQ0FBQ2xDLE9BQU8sQ0FBQ2lDLE1BQU0sQ0FBQ0MsSUFBSSxDQUFDN0I7SUFDM0IsRUFBRSxPQUFPK0IsS0FBSztRQUNaLElBQUksQ0FBQ3BDLE9BQU8sQ0FBQ2lDLE1BQU0sQ0FBQ0ksS0FBSyxDQUFDLENBQUMsMkNBQTJDLEVBQUVELElBQUlFLE9BQU8sQ0FBQyxDQUFDLEVBQUVGO1FBQ3ZGekIsUUFBUTRCLElBQUksQ0FBQztJQUNmO0FBQ0YifQ==
71
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uL3NyYy9jb25uZWN0LnRzIl0sInNvdXJjZXNDb250ZW50IjpbIi8qIGVzbGludC1kaXNhYmxlIEB0eXBlc2NyaXB0LWVzbGludC9uby12YXItcmVxdWlyZXMgKi9cbmltcG9ydCB0eXBlIHsgQ29ubmVjdE9wdGlvbnMgfSBmcm9tICdtb25nb29zZSdcbmltcG9ydCB0eXBlIHsgQ29ubmVjdCB9IGZyb20gJ3BheWxvYWQvZGF0YWJhc2UnXG5cbmltcG9ydCBtb25nb29zZSBmcm9tICdtb25nb29zZSdcblxuaW1wb3J0IHR5cGUgeyBNb25nb29zZUFkYXB0ZXIgfSBmcm9tICcuJ1xuXG5leHBvcnQgY29uc3QgY29ubmVjdDogQ29ubmVjdCA9IGFzeW5jIGZ1bmN0aW9uIGNvbm5lY3QodGhpczogTW9uZ29vc2VBZGFwdGVyLCBwYXlsb2FkKSB7XG4gIGlmICh0aGlzLnVybCA9PT0gZmFsc2UpIHtcbiAgICByZXR1cm5cbiAgfVxuXG4gIGlmICghcGF5bG9hZC5sb2NhbCAmJiB0eXBlb2YgdGhpcy51cmwgIT09ICdzdHJpbmcnKSB7XG4gICAgdGhyb3cgbmV3IEVycm9yKCdFcnJvcjogbWlzc2luZyBNb25nb0RCIGNvbm5lY3Rpb24gVVJMLicpXG4gIH1cblxuICBsZXQgdXJsVG9Db25uZWN0ID0gdGhpcy51cmxcbiAgbGV0IHN1Y2Nlc3NmdWxDb25uZWN0aW9uTWVzc2FnZSA9ICdDb25uZWN0ZWQgdG8gTW9uZ29EQiBzZXJ2ZXIgc3VjY2Vzc2Z1bGx5ISdcblxuICBjb25zdCBjb25uZWN0aW9uT3B0aW9uczogQ29ubmVjdE9wdGlvbnMgJiB7IHVzZUZhY2V0OiB1bmRlZmluZWQgfSA9IHtcbiAgICBhdXRvSW5kZXg6IHRydWUsXG4gICAgLi4udGhpcy5jb25uZWN0T3B0aW9ucyxcbiAgICB1c2VGYWNldDogdW5kZWZpbmVkLFxuICB9XG5cbiAgaWYgKHByb2Nlc3MuZW52Lk5PREVfRU5WID09PSAndGVzdCcpIHtcbiAgICBpZiAocHJvY2Vzcy5lbnYuUEFZTE9BRF9URVNUX01PTkdPX1VSTCkge1xuICAgICAgdXJsVG9Db25uZWN0ID0gcHJvY2Vzcy5lbnYuUEFZTE9BRF9URVNUX01PTkdPX1VSTFxuICAgIH0gZWxzZSB7XG4gICAgICBjb25uZWN0aW9uT3B0aW9ucy5kYk5hbWUgPSAncGF5bG9hZG1lbW9yeSdcbiAgICAgIGNvbnN0IHsgTW9uZ29NZW1vcnlSZXBsU2V0IH0gPSByZXF1aXJlKCdtb25nb2RiLW1lbW9yeS1zZXJ2ZXInKVxuICAgICAgY29uc3QgZ2V0UG9ydCA9IHJlcXVpcmUoJ2dldC1wb3J0JylcblxuICAgICAgY29uc3QgcG9ydCA9IGF3YWl0IGdldFBvcnQoKVxuICAgICAgdGhpcy5tb25nb01lbW9yeVNlcnZlciA9IGF3YWl0IE1vbmdvTWVtb3J5UmVwbFNldC5jcmVhdGUoe1xuICAgICAgICBpbnN0YW5jZToge1xuICAgICAgICAgIGRiTmFtZTogJ3BheWxvYWRtZW1vcnknLFxuICAgICAgICAgIHBvcnQsXG4gICAgICAgIH0sXG4gICAgICAgIHJlcGxTZXQ6IHtcbiAgICAgICAgICBjb3VudDogMyxcbiAgICAgICAgfSxcbiAgICAgIH0pXG5cbiAgICAgIHVybFRvQ29ubmVjdCA9IHRoaXMubW9uZ29NZW1vcnlTZXJ2ZXIuZ2V0VXJpKClcbiAgICAgIHN1Y2Nlc3NmdWxDb25uZWN0aW9uTWVzc2FnZSA9ICdDb25uZWN0ZWQgdG8gaW4tbWVtb3J5IE1vbmdvREIgc2VydmVyIHN1Y2Nlc3NmdWxseSEnXG4gICAgfVxuICB9XG5cbiAgdHJ5IHtcbiAgICB0aGlzLmNvbm5lY3Rpb24gPSAoYXdhaXQgbW9uZ29vc2UuY29ubmVjdCh1cmxUb0Nvbm5lY3QsIGNvbm5lY3Rpb25PcHRpb25zKSkuY29ubmVjdGlvblxuXG4gICAgY29uc3QgY2xpZW50ID0gdGhpcy5jb25uZWN0aW9uLmdldENsaWVudCgpXG5cbiAgICBpZiAoIWNsaWVudC5vcHRpb25zLnJlcGxpY2FTZXQpIHtcbiAgICAgIHRoaXMudHJhbnNhY3Rpb25PcHRpb25zID0gZmFsc2VcbiAgICAgIHRoaXMuYmVnaW5UcmFuc2FjdGlvbiA9IHVuZGVmaW5lZFxuICAgIH1cblxuICAgIGlmIChwcm9jZXNzLmVudi5QQVlMT0FEX0RST1BfREFUQUJBU0UgPT09ICd0cnVlJykge1xuICAgICAgdGhpcy5wYXlsb2FkLmxvZ2dlci5pbmZvKCctLS0tIERST1BQSU5HIERBVEFCQVNFIC0tLS0nKVxuICAgICAgYXdhaXQgbW9uZ29vc2UuY29ubmVjdGlvbi5kcm9wRGF0YWJhc2UoKVxuICAgICAgdGhpcy5wYXlsb2FkLmxvZ2dlci5pbmZvKCctLS0tIERST1BQRUQgREFUQUJBU0UgLS0tLScpXG4gICAgfVxuICAgIHRoaXMucGF5bG9hZC5sb2dnZXIuaW5mbyhzdWNjZXNzZnVsQ29ubmVjdGlvbk1lc3NhZ2UpXG4gIH0gY2F0Y2ggKGVycikge1xuICAgIHRoaXMucGF5bG9hZC5sb2dnZXIuZXJyb3IoYEVycm9yOiBjYW5ub3QgY29ubmVjdCB0byBNb25nb0RCLiBEZXRhaWxzOiAke2Vyci5tZXNzYWdlfWAsIGVycilcbiAgICBwcm9jZXNzLmV4aXQoMSlcbiAgfVxufVxuIl0sIm5hbWVzIjpbImNvbm5lY3QiLCJwYXlsb2FkIiwidXJsIiwibG9jYWwiLCJFcnJvciIsInVybFRvQ29ubmVjdCIsInN1Y2Nlc3NmdWxDb25uZWN0aW9uTWVzc2FnZSIsImNvbm5lY3Rpb25PcHRpb25zIiwiYXV0b0luZGV4IiwiY29ubmVjdE9wdGlvbnMiLCJ1c2VGYWNldCIsInVuZGVmaW5lZCIsInByb2Nlc3MiLCJlbnYiLCJOT0RFX0VOViIsIlBBWUxPQURfVEVTVF9NT05HT19VUkwiLCJkYk5hbWUiLCJNb25nb01lbW9yeVJlcGxTZXQiLCJyZXF1aXJlIiwiZ2V0UG9ydCIsInBvcnQiLCJtb25nb01lbW9yeVNlcnZlciIsImNyZWF0ZSIsImluc3RhbmNlIiwicmVwbFNldCIsImNvdW50IiwiZ2V0VXJpIiwiY29ubmVjdGlvbiIsIm1vbmdvb3NlIiwiY2xpZW50IiwiZ2V0Q2xpZW50Iiwib3B0aW9ucyIsInJlcGxpY2FTZXQiLCJ0cmFuc2FjdGlvbk9wdGlvbnMiLCJiZWdpblRyYW5zYWN0aW9uIiwiUEFZTE9BRF9EUk9QX0RBVEFCQVNFIiwibG9nZ2VyIiwiaW5mbyIsImRyb3BEYXRhYmFzZSIsImVyciIsImVycm9yIiwibWVzc2FnZSIsImV4aXQiXSwibWFwcGluZ3MiOiJBQUFBLHFEQUFxRDs7OzsrQkFReENBOzs7ZUFBQUE7OztpRUFKUTs7Ozs7O0FBSWQsTUFBTUEsVUFBbUIsZUFBZUEsUUFBK0JDLE9BQU87SUFDbkYsSUFBSSxJQUFJLENBQUNDLEdBQUcsS0FBSyxPQUFPO1FBQ3RCO0lBQ0Y7SUFFQSxJQUFJLENBQUNELFFBQVFFLEtBQUssSUFBSSxPQUFPLElBQUksQ0FBQ0QsR0FBRyxLQUFLLFVBQVU7UUFDbEQsTUFBTSxJQUFJRSxNQUFNO0lBQ2xCO0lBRUEsSUFBSUMsZUFBZSxJQUFJLENBQUNILEdBQUc7SUFDM0IsSUFBSUksOEJBQThCO0lBRWxDLE1BQU1DLG9CQUE4RDtRQUNsRUMsV0FBVztRQUNYLEdBQUcsSUFBSSxDQUFDQyxjQUFjO1FBQ3RCQyxVQUFVQztJQUNaO0lBRUEsSUFBSUMsUUFBUUMsR0FBRyxDQUFDQyxRQUFRLEtBQUssUUFBUTtRQUNuQyxJQUFJRixRQUFRQyxHQUFHLENBQUNFLHNCQUFzQixFQUFFO1lBQ3RDVixlQUFlTyxRQUFRQyxHQUFHLENBQUNFLHNCQUFzQjtRQUNuRCxPQUFPO1lBQ0xSLGtCQUFrQlMsTUFBTSxHQUFHO1lBQzNCLE1BQU0sRUFBRUMsa0JBQWtCLEVBQUUsR0FBR0MsUUFBUTtZQUN2QyxNQUFNQyxVQUFVRCxRQUFRO1lBRXhCLE1BQU1FLE9BQU8sTUFBTUQ7WUFDbkIsSUFBSSxDQUFDRSxpQkFBaUIsR0FBRyxNQUFNSixtQkFBbUJLLE1BQU0sQ0FBQztnQkFDdkRDLFVBQVU7b0JBQ1JQLFFBQVE7b0JBQ1JJO2dCQUNGO2dCQUNBSSxTQUFTO29CQUNQQyxPQUFPO2dCQUNUO1lBQ0Y7WUFFQXBCLGVBQWUsSUFBSSxDQUFDZ0IsaUJBQWlCLENBQUNLLE1BQU07WUFDNUNwQiw4QkFBOEI7UUFDaEM7SUFDRjtJQUVBLElBQUk7UUFDRixJQUFJLENBQUNxQixVQUFVLEdBQUcsQUFBQyxDQUFBLE1BQU1DLGlCQUFRLENBQUM1QixPQUFPLENBQUNLLGNBQWNFLGtCQUFpQixFQUFHb0IsVUFBVTtRQUV0RixNQUFNRSxTQUFTLElBQUksQ0FBQ0YsVUFBVSxDQUFDRyxTQUFTO1FBRXhDLElBQUksQ0FBQ0QsT0FBT0UsT0FBTyxDQUFDQyxVQUFVLEVBQUU7WUFDOUIsSUFBSSxDQUFDQyxrQkFBa0IsR0FBRztZQUMxQixJQUFJLENBQUNDLGdCQUFnQixHQUFHdkI7UUFDMUI7UUFFQSxJQUFJQyxRQUFRQyxHQUFHLENBQUNzQixxQkFBcUIsS0FBSyxRQUFRO1lBQ2hELElBQUksQ0FBQ2xDLE9BQU8sQ0FBQ21DLE1BQU0sQ0FBQ0MsSUFBSSxDQUFDO1lBQ3pCLE1BQU1ULGlCQUFRLENBQUNELFVBQVUsQ0FBQ1csWUFBWTtZQUN0QyxJQUFJLENBQUNyQyxPQUFPLENBQUNtQyxNQUFNLENBQUNDLElBQUksQ0FBQztRQUMzQjtRQUNBLElBQUksQ0FBQ3BDLE9BQU8sQ0FBQ21DLE1BQU0sQ0FBQ0MsSUFBSSxDQUFDL0I7SUFDM0IsRUFBRSxPQUFPaUMsS0FBSztRQUNaLElBQUksQ0FBQ3RDLE9BQU8sQ0FBQ21DLE1BQU0sQ0FBQ0ksS0FBSyxDQUFDLENBQUMsMkNBQTJDLEVBQUVELElBQUlFLE9BQU8sQ0FBQyxDQUFDLEVBQUVGO1FBQ3ZGM0IsUUFBUThCLElBQUksQ0FBQztJQUNmO0FBQ0YifQ==
@@ -36,7 +36,7 @@ const createMigration = async function createMigration({ file, migrationName, pa
36
36
  let migrationFileContent;
37
37
  // Check for predefined migration.
38
38
  // Either passed in via --file or prefixed with @payloadcms/db-mongodb/
39
- if (file || migrationName.startsWith('@payloadcms/db-mongodb/')) {
39
+ if (file || migrationName?.startsWith('@payloadcms/db-mongodb/')) {
40
40
  if (!file) file = migrationName;
41
41
  const predefinedMigrationName = file.replace('@payloadcms/db-mongodb/', '');
42
42
  migrationName = predefinedMigrationName;
@@ -58,8 +58,8 @@ const createMigration = async function createMigration({ file, migrationName, pa
58
58
  const formattedDate = yyymmdd.replace(/\D/g, '');
59
59
  const formattedTime = hhmmss.split('.')[0].replace(/\D/g, '');
60
60
  const timestamp = `${formattedDate}_${formattedTime}`;
61
- const formattedName = migrationName.replace(/\W/g, '_');
62
- const fileName = `${timestamp}_${formattedName}.ts`;
61
+ const formattedName = migrationName?.replace(/\W/g, '_');
62
+ const fileName = migrationName ? `${timestamp}_${formattedName}.ts` : `${timestamp}_migration.ts`;
63
63
  const filePath = `${dir}/${fileName}`;
64
64
  _fs.default.writeFileSync(filePath, migrationFileContent);
65
65
  payload.logger.info({
@@ -67,4 +67,4 @@ const createMigration = async function createMigration({ file, migrationName, pa
67
67
  });
68
68
  };
69
69
 
70
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uL3NyYy9jcmVhdGVNaWdyYXRpb24udHMiXSwic291cmNlc0NvbnRlbnQiOlsiLyogZXNsaW50LWRpc2FibGUgbm8tcmVzdHJpY3RlZC1zeW50YXgsIG5vLWF3YWl0LWluLWxvb3AgKi9cbmltcG9ydCB0eXBlIHsgQ3JlYXRlTWlncmF0aW9uIH0gZnJvbSAncGF5bG9hZC9kYXRhYmFzZSdcblxuaW1wb3J0IGZzIGZyb20gJ2ZzJ1xuaW1wb3J0IHBhdGggZnJvbSAncGF0aCdcblxuY29uc3QgbWlncmF0aW9uVGVtcGxhdGUgPSAodXBTUUw/OiBzdHJpbmcsIGRvd25TUUw/OiBzdHJpbmcpID0+IGBpbXBvcnQge1xuICBNaWdyYXRlVXBBcmdzLFxuICBNaWdyYXRlRG93bkFyZ3MsXG59IGZyb20gXCJAcGF5bG9hZGNtcy9kYi1tb25nb2RiXCI7XG5cbmV4cG9ydCBhc3luYyBmdW5jdGlvbiB1cCh7IHBheWxvYWQgfTogTWlncmF0ZVVwQXJncyk6IFByb21pc2U8dm9pZD4ge1xuJHt1cFNRTCA/PyBgICAvLyBNaWdyYXRpb24gY29kZWB9XG59O1xuXG5leHBvcnQgYXN5bmMgZnVuY3Rpb24gZG93bih7IHBheWxvYWQgfTogTWlncmF0ZURvd25BcmdzKTogUHJvbWlzZTx2b2lkPiB7XG4ke2Rvd25TUUwgPz8gYCAgLy8gTWlncmF0aW9uIGNvZGVgfVxufTtcbmBcblxuZXhwb3J0IGNvbnN0IGNyZWF0ZU1pZ3JhdGlvbjogQ3JlYXRlTWlncmF0aW9uID0gYXN5bmMgZnVuY3Rpb24gY3JlYXRlTWlncmF0aW9uKHtcbiAgZmlsZSxcbiAgbWlncmF0aW9uTmFtZSxcbiAgcGF5bG9hZCxcbn0pIHtcbiAgY29uc3QgZGlyID0gcGF5bG9hZC5kYi5taWdyYXRpb25EaXJcbiAgaWYgKCFmcy5leGlzdHNTeW5jKGRpcikpIHtcbiAgICBmcy5ta2RpclN5bmMoZGlyKVxuICB9XG5cbiAgbGV0IG1pZ3JhdGlvbkZpbGVDb250ZW50OiBzdHJpbmcgfCB1bmRlZmluZWRcblxuICAvLyBDaGVjayBmb3IgcHJlZGVmaW5lZCBtaWdyYXRpb24uXG4gIC8vIEVpdGhlciBwYXNzZWQgaW4gdmlhIC0tZmlsZSBvciBwcmVmaXhlZCB3aXRoIEBwYXlsb2FkY21zL2RiLW1vbmdvZGIvXG4gIGlmIChmaWxlIHx8IG1pZ3JhdGlvbk5hbWUuc3RhcnRzV2l0aCgnQHBheWxvYWRjbXMvZGItbW9uZ29kYi8nKSkge1xuICAgIGlmICghZmlsZSkgZmlsZSA9IG1pZ3JhdGlvbk5hbWVcblxuICAgIGNvbnN0IHByZWRlZmluZWRNaWdyYXRpb25OYW1lID0gZmlsZS5yZXBsYWNlKCdAcGF5bG9hZGNtcy9kYi1tb25nb2RiLycsICcnKVxuICAgIG1pZ3JhdGlvbk5hbWUgPSBwcmVkZWZpbmVkTWlncmF0aW9uTmFtZVxuICAgIGNvbnN0IGNsZWFuUGF0aCA9IHBhdGguam9pbihfX2Rpcm5hbWUsIGAuLi9wcmVkZWZpbmVkTWlncmF0aW9ucy8ke3ByZWRlZmluZWRNaWdyYXRpb25OYW1lfS5qc2ApXG5cbiAgICAvLyBDaGVjayBpZiBwcmVkZWZpbmVkIG1pZ3JhdGlvbiBleGlzdHNcbiAgICBpZiAoZnMuZXhpc3RzU3luYyhjbGVhblBhdGgpKSB7XG4gICAgICBjb25zdCB7IGRvd24sIHVwIH0gPSByZXF1aXJlKGNsZWFuUGF0aClcbiAgICAgIG1pZ3JhdGlvbkZpbGVDb250ZW50ID0gbWlncmF0aW9uVGVtcGxhdGUodXAsIGRvd24pXG4gICAgfSBlbHNlIHtcbiAgICAgIHBheWxvYWQubG9nZ2VyLmVycm9yKHtcbiAgICAgICAgbXNnOiBgQ2FubmVkIG1pZ3JhdGlvbiAke3ByZWRlZmluZWRNaWdyYXRpb25OYW1lfSBub3QgZm91bmQuYCxcbiAgICAgIH0pXG4gICAgICBwcm9jZXNzLmV4aXQoMSlcbiAgICB9XG4gIH0gZWxzZSB7XG4gICAgbWlncmF0aW9uRmlsZUNvbnRlbnQgPSBtaWdyYXRpb25UZW1wbGF0ZSgpXG4gIH1cblxuICBjb25zdCBbeXl5bW1kZCwgaGhtbXNzXSA9IG5ldyBEYXRlKCkudG9JU09TdHJpbmcoKS5zcGxpdCgnVCcpXG4gIGNvbnN0IGZvcm1hdHRlZERhdGUgPSB5eXltbWRkLnJlcGxhY2UoL1xcRC9nLCAnJylcbiAgY29uc3QgZm9ybWF0dGVkVGltZSA9IGhobW1zcy5zcGxpdCgnLicpWzBdLnJlcGxhY2UoL1xcRC9nLCAnJylcblxuICBjb25zdCB0aW1lc3RhbXAgPSBgJHtmb3JtYXR0ZWREYXRlfV8ke2Zvcm1hdHRlZFRpbWV9YFxuXG4gIGNvbnN0IGZvcm1hdHRlZE5hbWUgPSBtaWdyYXRpb25OYW1lLnJlcGxhY2UoL1xcVy9nLCAnXycpXG4gIGNvbnN0IGZpbGVOYW1lID0gYCR7dGltZXN0YW1wfV8ke2Zvcm1hdHRlZE5hbWV9LnRzYFxuICBjb25zdCBmaWxlUGF0aCA9IGAke2Rpcn0vJHtmaWxlTmFtZX1gXG4gIGZzLndyaXRlRmlsZVN5bmMoZmlsZVBhdGgsIG1pZ3JhdGlvbkZpbGVDb250ZW50KVxuICBwYXlsb2FkLmxvZ2dlci5pbmZvKHsgbXNnOiBgTWlncmF0aW9uIGNyZWF0ZWQgYXQgJHtmaWxlUGF0aH1gIH0pXG59XG4iXSwibmFtZXMiOlsiY3JlYXRlTWlncmF0aW9uIiwibWlncmF0aW9uVGVtcGxhdGUiLCJ1cFNRTCIsImRvd25TUUwiLCJmaWxlIiwibWlncmF0aW9uTmFtZSIsInBheWxvYWQiLCJkaXIiLCJkYiIsIm1pZ3JhdGlvbkRpciIsImZzIiwiZXhpc3RzU3luYyIsIm1rZGlyU3luYyIsIm1pZ3JhdGlvbkZpbGVDb250ZW50Iiwic3RhcnRzV2l0aCIsInByZWRlZmluZWRNaWdyYXRpb25OYW1lIiwicmVwbGFjZSIsImNsZWFuUGF0aCIsInBhdGgiLCJqb2luIiwiX19kaXJuYW1lIiwiZG93biIsInVwIiwicmVxdWlyZSIsImxvZ2dlciIsImVycm9yIiwibXNnIiwicHJvY2VzcyIsImV4aXQiLCJ5eXltbWRkIiwiaGhtbXNzIiwiRGF0ZSIsInRvSVNPU3RyaW5nIiwic3BsaXQiLCJmb3JtYXR0ZWREYXRlIiwiZm9ybWF0dGVkVGltZSIsInRpbWVzdGFtcCIsImZvcm1hdHRlZE5hbWUiLCJmaWxlTmFtZSIsImZpbGVQYXRoIiwid3JpdGVGaWxlU3luYyIsImluZm8iXSwibWFwcGluZ3MiOiJBQUFBLHlEQUF5RDs7OzsrQkFvQjVDQTs7O2VBQUFBOzs7MkRBakJFOzZEQUNFOzs7Ozs7QUFFakIsTUFBTUMsb0JBQW9CLENBQUNDLE9BQWdCQyxVQUFxQixDQUFDOzs7Ozs7QUFNakUsRUFBRUQsU0FBUyxDQUFDLG1CQUFtQixDQUFDLENBQUM7Ozs7QUFJakMsRUFBRUMsV0FBVyxDQUFDLG1CQUFtQixDQUFDLENBQUM7O0FBRW5DLENBQUM7QUFFTSxNQUFNSCxrQkFBbUMsZUFBZUEsZ0JBQWdCLEVBQzdFSSxJQUFJLEVBQ0pDLGFBQWEsRUFDYkMsT0FBTyxFQUNSO0lBQ0MsTUFBTUMsTUFBTUQsUUFBUUUsRUFBRSxDQUFDQyxZQUFZO0lBQ25DLElBQUksQ0FBQ0MsV0FBRSxDQUFDQyxVQUFVLENBQUNKLE1BQU07UUFDdkJHLFdBQUUsQ0FBQ0UsU0FBUyxDQUFDTDtJQUNmO0lBRUEsSUFBSU07SUFFSixrQ0FBa0M7SUFDbEMsdUVBQXVFO0lBQ3ZFLElBQUlULFFBQVFDLGNBQWNTLFVBQVUsQ0FBQyw0QkFBNEI7UUFDL0QsSUFBSSxDQUFDVixNQUFNQSxPQUFPQztRQUVsQixNQUFNVSwwQkFBMEJYLEtBQUtZLE9BQU8sQ0FBQywyQkFBMkI7UUFDeEVYLGdCQUFnQlU7UUFDaEIsTUFBTUUsWUFBWUMsYUFBSSxDQUFDQyxJQUFJLENBQUNDLFdBQVcsQ0FBQyx3QkFBd0IsRUFBRUwsd0JBQXdCLEdBQUcsQ0FBQztRQUU5Rix1Q0FBdUM7UUFDdkMsSUFBSUwsV0FBRSxDQUFDQyxVQUFVLENBQUNNLFlBQVk7WUFDNUIsTUFBTSxFQUFFSSxJQUFJLEVBQUVDLEVBQUUsRUFBRSxHQUFHQyxRQUFRTjtZQUM3QkosdUJBQXVCWixrQkFBa0JxQixJQUFJRDtRQUMvQyxPQUFPO1lBQ0xmLFFBQVFrQixNQUFNLENBQUNDLEtBQUssQ0FBQztnQkFDbkJDLEtBQUssQ0FBQyxpQkFBaUIsRUFBRVgsd0JBQXdCLFdBQVcsQ0FBQztZQUMvRDtZQUNBWSxRQUFRQyxJQUFJLENBQUM7UUFDZjtJQUNGLE9BQU87UUFDTGYsdUJBQXVCWjtJQUN6QjtJQUVBLE1BQU0sQ0FBQzRCLFNBQVNDLE9BQU8sR0FBRyxJQUFJQyxPQUFPQyxXQUFXLEdBQUdDLEtBQUssQ0FBQztJQUN6RCxNQUFNQyxnQkFBZ0JMLFFBQVFiLE9BQU8sQ0FBQyxPQUFPO0lBQzdDLE1BQU1tQixnQkFBZ0JMLE9BQU9HLEtBQUssQ0FBQyxJQUFJLENBQUMsRUFBRSxDQUFDakIsT0FBTyxDQUFDLE9BQU87SUFFMUQsTUFBTW9CLFlBQVksQ0FBQyxFQUFFRixjQUFjLENBQUMsRUFBRUMsY0FBYyxDQUFDO0lBRXJELE1BQU1FLGdCQUFnQmhDLGNBQWNXLE9BQU8sQ0FBQyxPQUFPO0lBQ25ELE1BQU1zQixXQUFXLENBQUMsRUFBRUYsVUFBVSxDQUFDLEVBQUVDLGNBQWMsR0FBRyxDQUFDO0lBQ25ELE1BQU1FLFdBQVcsQ0FBQyxFQUFFaEMsSUFBSSxDQUFDLEVBQUUrQixTQUFTLENBQUM7SUFDckM1QixXQUFFLENBQUM4QixhQUFhLENBQUNELFVBQVUxQjtJQUMzQlAsUUFBUWtCLE1BQU0sQ0FBQ2lCLElBQUksQ0FBQztRQUFFZixLQUFLLENBQUMscUJBQXFCLEVBQUVhLFNBQVMsQ0FBQztJQUFDO0FBQ2hFIn0=
70
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uL3NyYy9jcmVhdGVNaWdyYXRpb24udHMiXSwic291cmNlc0NvbnRlbnQiOlsiLyogZXNsaW50LWRpc2FibGUgbm8tcmVzdHJpY3RlZC1zeW50YXgsIG5vLWF3YWl0LWluLWxvb3AgKi9cbmltcG9ydCB0eXBlIHsgQ3JlYXRlTWlncmF0aW9uIH0gZnJvbSAncGF5bG9hZC9kYXRhYmFzZSdcblxuaW1wb3J0IGZzIGZyb20gJ2ZzJ1xuaW1wb3J0IHBhdGggZnJvbSAncGF0aCdcblxuY29uc3QgbWlncmF0aW9uVGVtcGxhdGUgPSAodXBTUUw/OiBzdHJpbmcsIGRvd25TUUw/OiBzdHJpbmcpID0+IGBpbXBvcnQge1xuICBNaWdyYXRlVXBBcmdzLFxuICBNaWdyYXRlRG93bkFyZ3MsXG59IGZyb20gXCJAcGF5bG9hZGNtcy9kYi1tb25nb2RiXCI7XG5cbmV4cG9ydCBhc3luYyBmdW5jdGlvbiB1cCh7IHBheWxvYWQgfTogTWlncmF0ZVVwQXJncyk6IFByb21pc2U8dm9pZD4ge1xuJHt1cFNRTCA/PyBgICAvLyBNaWdyYXRpb24gY29kZWB9XG59O1xuXG5leHBvcnQgYXN5bmMgZnVuY3Rpb24gZG93bih7IHBheWxvYWQgfTogTWlncmF0ZURvd25BcmdzKTogUHJvbWlzZTx2b2lkPiB7XG4ke2Rvd25TUUwgPz8gYCAgLy8gTWlncmF0aW9uIGNvZGVgfVxufTtcbmBcblxuZXhwb3J0IGNvbnN0IGNyZWF0ZU1pZ3JhdGlvbjogQ3JlYXRlTWlncmF0aW9uID0gYXN5bmMgZnVuY3Rpb24gY3JlYXRlTWlncmF0aW9uKHtcbiAgZmlsZSxcbiAgbWlncmF0aW9uTmFtZSxcbiAgcGF5bG9hZCxcbn0pIHtcbiAgY29uc3QgZGlyID0gcGF5bG9hZC5kYi5taWdyYXRpb25EaXJcbiAgaWYgKCFmcy5leGlzdHNTeW5jKGRpcikpIHtcbiAgICBmcy5ta2RpclN5bmMoZGlyKVxuICB9XG5cbiAgbGV0IG1pZ3JhdGlvbkZpbGVDb250ZW50OiBzdHJpbmcgfCB1bmRlZmluZWRcblxuICAvLyBDaGVjayBmb3IgcHJlZGVmaW5lZCBtaWdyYXRpb24uXG4gIC8vIEVpdGhlciBwYXNzZWQgaW4gdmlhIC0tZmlsZSBvciBwcmVmaXhlZCB3aXRoIEBwYXlsb2FkY21zL2RiLW1vbmdvZGIvXG4gIGlmIChmaWxlIHx8IG1pZ3JhdGlvbk5hbWU/LnN0YXJ0c1dpdGgoJ0BwYXlsb2FkY21zL2RiLW1vbmdvZGIvJykpIHtcbiAgICBpZiAoIWZpbGUpIGZpbGUgPSBtaWdyYXRpb25OYW1lXG5cbiAgICBjb25zdCBwcmVkZWZpbmVkTWlncmF0aW9uTmFtZSA9IGZpbGUucmVwbGFjZSgnQHBheWxvYWRjbXMvZGItbW9uZ29kYi8nLCAnJylcbiAgICBtaWdyYXRpb25OYW1lID0gcHJlZGVmaW5lZE1pZ3JhdGlvbk5hbWVcbiAgICBjb25zdCBjbGVhblBhdGggPSBwYXRoLmpvaW4oX19kaXJuYW1lLCBgLi4vcHJlZGVmaW5lZE1pZ3JhdGlvbnMvJHtwcmVkZWZpbmVkTWlncmF0aW9uTmFtZX0uanNgKVxuXG4gICAgLy8gQ2hlY2sgaWYgcHJlZGVmaW5lZCBtaWdyYXRpb24gZXhpc3RzXG4gICAgaWYgKGZzLmV4aXN0c1N5bmMoY2xlYW5QYXRoKSkge1xuICAgICAgY29uc3QgeyBkb3duLCB1cCB9ID0gcmVxdWlyZShjbGVhblBhdGgpXG4gICAgICBtaWdyYXRpb25GaWxlQ29udGVudCA9IG1pZ3JhdGlvblRlbXBsYXRlKHVwLCBkb3duKVxuICAgIH0gZWxzZSB7XG4gICAgICBwYXlsb2FkLmxvZ2dlci5lcnJvcih7XG4gICAgICAgIG1zZzogYENhbm5lZCBtaWdyYXRpb24gJHtwcmVkZWZpbmVkTWlncmF0aW9uTmFtZX0gbm90IGZvdW5kLmAsXG4gICAgICB9KVxuICAgICAgcHJvY2Vzcy5leGl0KDEpXG4gICAgfVxuICB9IGVsc2Uge1xuICAgIG1pZ3JhdGlvbkZpbGVDb250ZW50ID0gbWlncmF0aW9uVGVtcGxhdGUoKVxuICB9XG5cbiAgY29uc3QgW3l5eW1tZGQsIGhobW1zc10gPSBuZXcgRGF0ZSgpLnRvSVNPU3RyaW5nKCkuc3BsaXQoJ1QnKVxuICBjb25zdCBmb3JtYXR0ZWREYXRlID0geXl5bW1kZC5yZXBsYWNlKC9cXEQvZywgJycpXG4gIGNvbnN0IGZvcm1hdHRlZFRpbWUgPSBoaG1tc3Muc3BsaXQoJy4nKVswXS5yZXBsYWNlKC9cXEQvZywgJycpXG5cbiAgY29uc3QgdGltZXN0YW1wID0gYCR7Zm9ybWF0dGVkRGF0ZX1fJHtmb3JtYXR0ZWRUaW1lfWBcblxuICBjb25zdCBmb3JtYXR0ZWROYW1lID0gbWlncmF0aW9uTmFtZT8ucmVwbGFjZSgvXFxXL2csICdfJylcbiAgY29uc3QgZmlsZU5hbWUgPSBtaWdyYXRpb25OYW1lID8gYCR7dGltZXN0YW1wfV8ke2Zvcm1hdHRlZE5hbWV9LnRzYCA6IGAke3RpbWVzdGFtcH1fbWlncmF0aW9uLnRzYFxuICBjb25zdCBmaWxlUGF0aCA9IGAke2Rpcn0vJHtmaWxlTmFtZX1gXG4gIGZzLndyaXRlRmlsZVN5bmMoZmlsZVBhdGgsIG1pZ3JhdGlvbkZpbGVDb250ZW50KVxuICBwYXlsb2FkLmxvZ2dlci5pbmZvKHsgbXNnOiBgTWlncmF0aW9uIGNyZWF0ZWQgYXQgJHtmaWxlUGF0aH1gIH0pXG59XG4iXSwibmFtZXMiOlsiY3JlYXRlTWlncmF0aW9uIiwibWlncmF0aW9uVGVtcGxhdGUiLCJ1cFNRTCIsImRvd25TUUwiLCJmaWxlIiwibWlncmF0aW9uTmFtZSIsInBheWxvYWQiLCJkaXIiLCJkYiIsIm1pZ3JhdGlvbkRpciIsImZzIiwiZXhpc3RzU3luYyIsIm1rZGlyU3luYyIsIm1pZ3JhdGlvbkZpbGVDb250ZW50Iiwic3RhcnRzV2l0aCIsInByZWRlZmluZWRNaWdyYXRpb25OYW1lIiwicmVwbGFjZSIsImNsZWFuUGF0aCIsInBhdGgiLCJqb2luIiwiX19kaXJuYW1lIiwiZG93biIsInVwIiwicmVxdWlyZSIsImxvZ2dlciIsImVycm9yIiwibXNnIiwicHJvY2VzcyIsImV4aXQiLCJ5eXltbWRkIiwiaGhtbXNzIiwiRGF0ZSIsInRvSVNPU3RyaW5nIiwic3BsaXQiLCJmb3JtYXR0ZWREYXRlIiwiZm9ybWF0dGVkVGltZSIsInRpbWVzdGFtcCIsImZvcm1hdHRlZE5hbWUiLCJmaWxlTmFtZSIsImZpbGVQYXRoIiwid3JpdGVGaWxlU3luYyIsImluZm8iXSwibWFwcGluZ3MiOiJBQUFBLHlEQUF5RDs7OzsrQkFvQjVDQTs7O2VBQUFBOzs7MkRBakJFOzZEQUNFOzs7Ozs7QUFFakIsTUFBTUMsb0JBQW9CLENBQUNDLE9BQWdCQyxVQUFxQixDQUFDOzs7Ozs7QUFNakUsRUFBRUQsU0FBUyxDQUFDLG1CQUFtQixDQUFDLENBQUM7Ozs7QUFJakMsRUFBRUMsV0FBVyxDQUFDLG1CQUFtQixDQUFDLENBQUM7O0FBRW5DLENBQUM7QUFFTSxNQUFNSCxrQkFBbUMsZUFBZUEsZ0JBQWdCLEVBQzdFSSxJQUFJLEVBQ0pDLGFBQWEsRUFDYkMsT0FBTyxFQUNSO0lBQ0MsTUFBTUMsTUFBTUQsUUFBUUUsRUFBRSxDQUFDQyxZQUFZO0lBQ25DLElBQUksQ0FBQ0MsV0FBRSxDQUFDQyxVQUFVLENBQUNKLE1BQU07UUFDdkJHLFdBQUUsQ0FBQ0UsU0FBUyxDQUFDTDtJQUNmO0lBRUEsSUFBSU07SUFFSixrQ0FBa0M7SUFDbEMsdUVBQXVFO0lBQ3ZFLElBQUlULFFBQVFDLGVBQWVTLFdBQVcsNEJBQTRCO1FBQ2hFLElBQUksQ0FBQ1YsTUFBTUEsT0FBT0M7UUFFbEIsTUFBTVUsMEJBQTBCWCxLQUFLWSxPQUFPLENBQUMsMkJBQTJCO1FBQ3hFWCxnQkFBZ0JVO1FBQ2hCLE1BQU1FLFlBQVlDLGFBQUksQ0FBQ0MsSUFBSSxDQUFDQyxXQUFXLENBQUMsd0JBQXdCLEVBQUVMLHdCQUF3QixHQUFHLENBQUM7UUFFOUYsdUNBQXVDO1FBQ3ZDLElBQUlMLFdBQUUsQ0FBQ0MsVUFBVSxDQUFDTSxZQUFZO1lBQzVCLE1BQU0sRUFBRUksSUFBSSxFQUFFQyxFQUFFLEVBQUUsR0FBR0MsUUFBUU47WUFDN0JKLHVCQUF1Qlosa0JBQWtCcUIsSUFBSUQ7UUFDL0MsT0FBTztZQUNMZixRQUFRa0IsTUFBTSxDQUFDQyxLQUFLLENBQUM7Z0JBQ25CQyxLQUFLLENBQUMsaUJBQWlCLEVBQUVYLHdCQUF3QixXQUFXLENBQUM7WUFDL0Q7WUFDQVksUUFBUUMsSUFBSSxDQUFDO1FBQ2Y7SUFDRixPQUFPO1FBQ0xmLHVCQUF1Qlo7SUFDekI7SUFFQSxNQUFNLENBQUM0QixTQUFTQyxPQUFPLEdBQUcsSUFBSUMsT0FBT0MsV0FBVyxHQUFHQyxLQUFLLENBQUM7SUFDekQsTUFBTUMsZ0JBQWdCTCxRQUFRYixPQUFPLENBQUMsT0FBTztJQUM3QyxNQUFNbUIsZ0JBQWdCTCxPQUFPRyxLQUFLLENBQUMsSUFBSSxDQUFDLEVBQUUsQ0FBQ2pCLE9BQU8sQ0FBQyxPQUFPO0lBRTFELE1BQU1vQixZQUFZLENBQUMsRUFBRUYsY0FBYyxDQUFDLEVBQUVDLGNBQWMsQ0FBQztJQUVyRCxNQUFNRSxnQkFBZ0JoQyxlQUFlVyxRQUFRLE9BQU87SUFDcEQsTUFBTXNCLFdBQVdqQyxnQkFBZ0IsQ0FBQyxFQUFFK0IsVUFBVSxDQUFDLEVBQUVDLGNBQWMsR0FBRyxDQUFDLEdBQUcsQ0FBQyxFQUFFRCxVQUFVLGFBQWEsQ0FBQztJQUNqRyxNQUFNRyxXQUFXLENBQUMsRUFBRWhDLElBQUksQ0FBQyxFQUFFK0IsU0FBUyxDQUFDO0lBQ3JDNUIsV0FBRSxDQUFDOEIsYUFBYSxDQUFDRCxVQUFVMUI7SUFDM0JQLFFBQVFrQixNQUFNLENBQUNpQixJQUFJLENBQUM7UUFBRWYsS0FBSyxDQUFDLHFCQUFxQixFQUFFYSxTQUFTLENBQUM7SUFBQztBQUNoRSJ9
@@ -2,5 +2,7 @@ import type { MongooseAdapter } from '.';
2
2
  /**
3
3
  * Drop the current database and run all migrate up functions
4
4
  */
5
- export declare function migrateFresh(this: MongooseAdapter): Promise<void>;
5
+ export declare function migrateFresh(this: MongooseAdapter, { forceAcceptWarning }: {
6
+ forceAcceptWarning?: boolean;
7
+ }): Promise<void>;
6
8
  //# sourceMappingURL=migrateFresh.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"migrateFresh.d.ts","sourceRoot":"","sources":["../src/migrateFresh.ts"],"names":[],"mappings":"AAQA,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,GAAG,CAAA;AAExC;;GAEG;AACH,wBAAsB,YAAY,CAAC,IAAI,EAAE,eAAe,GAAG,OAAO,CAAC,IAAI,CAAC,CA8DvE"}
1
+ {"version":3,"file":"migrateFresh.d.ts","sourceRoot":"","sources":["../src/migrateFresh.ts"],"names":[],"mappings":"AAQA,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,GAAG,CAAA;AAExC;;GAEG;AACH,wBAAsB,YAAY,CAChC,IAAI,EAAE,eAAe,EACrB,EAAE,kBAA0B,EAAE,EAAE;IAAE,kBAAkB,CAAC,EAAE,OAAO,CAAA;CAAE,GAC/D,OAAO,CAAC,IAAI,CAAC,CAgEf"}
@@ -18,20 +18,22 @@ function _interop_require_default(obj) {
18
18
  default: obj
19
19
  };
20
20
  }
21
- async function migrateFresh() {
21
+ async function migrateFresh({ forceAcceptWarning = false }) {
22
22
  const { payload } = this;
23
- const { confirm: acceptWarning } = await (0, _prompts.default)({
24
- name: 'confirm',
25
- type: 'confirm',
26
- initial: false,
27
- message: `WARNING: This will drop your database and run all migrations. Are you sure you want to proceed?`
28
- }, {
29
- onCancel: ()=>{
23
+ if (!forceAcceptWarning) {
24
+ const { confirm: acceptWarning } = await (0, _prompts.default)({
25
+ name: 'confirm',
26
+ type: 'confirm',
27
+ initial: false,
28
+ message: `WARNING: This will drop your database and run all migrations. Are you sure you want to proceed?`
29
+ }, {
30
+ onCancel: ()=>{
31
+ process.exit(0);
32
+ }
33
+ });
34
+ if (!acceptWarning) {
30
35
  process.exit(0);
31
36
  }
32
- });
33
- if (!acceptWarning) {
34
- process.exit(0);
35
37
  }
36
38
  payload.logger.info({
37
39
  msg: `Dropping database.`
@@ -81,4 +83,4 @@ async function migrateFresh() {
81
83
  }
82
84
  }
83
85
 
84
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uL3NyYy9taWdyYXRlRnJlc2gudHMiXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHR5cGUgeyBQYXlsb2FkUmVxdWVzdCB9IGZyb20gJ3BheWxvYWQvdHlwZXMnXG5cbmltcG9ydCB7IHJlYWRNaWdyYXRpb25GaWxlcyB9IGZyb20gJ3BheWxvYWQvZGF0YWJhc2UnXG5pbXBvcnQgeyBjb21taXRUcmFuc2FjdGlvbiB9IGZyb20gJ3BheWxvYWQvZGlzdC91dGlsaXRpZXMvY29tbWl0VHJhbnNhY3Rpb24nXG5pbXBvcnQgeyBpbml0VHJhbnNhY3Rpb24gfSBmcm9tICdwYXlsb2FkL2Rpc3QvdXRpbGl0aWVzL2luaXRUcmFuc2FjdGlvbidcbmltcG9ydCB7IGtpbGxUcmFuc2FjdGlvbiB9IGZyb20gJ3BheWxvYWQvZGlzdC91dGlsaXRpZXMva2lsbFRyYW5zYWN0aW9uJ1xuaW1wb3J0IHByb21wdHMgZnJvbSAncHJvbXB0cydcblxuaW1wb3J0IHR5cGUgeyBNb25nb29zZUFkYXB0ZXIgfSBmcm9tICcuJ1xuXG4vKipcbiAqIERyb3AgdGhlIGN1cnJlbnQgZGF0YWJhc2UgYW5kIHJ1biBhbGwgbWlncmF0ZSB1cCBmdW5jdGlvbnNcbiAqL1xuZXhwb3J0IGFzeW5jIGZ1bmN0aW9uIG1pZ3JhdGVGcmVzaCh0aGlzOiBNb25nb29zZUFkYXB0ZXIpOiBQcm9taXNlPHZvaWQ+IHtcbiAgY29uc3QgeyBwYXlsb2FkIH0gPSB0aGlzXG5cbiAgY29uc3QgeyBjb25maXJtOiBhY2NlcHRXYXJuaW5nIH0gPSBhd2FpdCBwcm9tcHRzKFxuICAgIHtcbiAgICAgIG5hbWU6ICdjb25maXJtJyxcbiAgICAgIHR5cGU6ICdjb25maXJtJyxcbiAgICAgIGluaXRpYWw6IGZhbHNlLFxuICAgICAgbWVzc2FnZTogYFdBUk5JTkc6IFRoaXMgd2lsbCBkcm9wIHlvdXIgZGF0YWJhc2UgYW5kIHJ1biBhbGwgbWlncmF0aW9ucy4gQXJlIHlvdSBzdXJlIHlvdSB3YW50IHRvIHByb2NlZWQ/YCxcbiAgICB9LFxuICAgIHtcbiAgICAgIG9uQ2FuY2VsOiAoKSA9PiB7XG4gICAgICAgIHByb2Nlc3MuZXhpdCgwKVxuICAgICAgfSxcbiAgICB9LFxuICApXG5cbiAgaWYgKCFhY2NlcHRXYXJuaW5nKSB7XG4gICAgcHJvY2Vzcy5leGl0KDApXG4gIH1cblxuICBwYXlsb2FkLmxvZ2dlci5pbmZvKHtcbiAgICBtc2c6IGBEcm9wcGluZyBkYXRhYmFzZS5gLFxuICB9KVxuXG4gIGF3YWl0IHRoaXMuY29ubmVjdGlvbi5kcm9wRGF0YWJhc2UoKVxuXG4gIGNvbnN0IG1pZ3JhdGlvbkZpbGVzID0gYXdhaXQgcmVhZE1pZ3JhdGlvbkZpbGVzKHsgcGF5bG9hZCB9KVxuICBwYXlsb2FkLmxvZ2dlci5kZWJ1Zyh7XG4gICAgbXNnOiBgRm91bmQgJHttaWdyYXRpb25GaWxlcy5sZW5ndGh9IG1pZ3JhdGlvbiBmaWxlcy5gLFxuICB9KVxuXG4gIGNvbnN0IHJlcSA9IHsgcGF5bG9hZCB9IGFzIFBheWxvYWRSZXF1ZXN0XG5cbiAgLy8gUnVuIGFsbCBtaWdyYXRlIHVwXG4gIGZvciAoY29uc3QgbWlncmF0aW9uIG9mIG1pZ3JhdGlvbkZpbGVzKSB7XG4gICAgcGF5bG9hZC5sb2dnZXIuaW5mbyh7IG1zZzogYE1pZ3JhdGluZzogJHttaWdyYXRpb24ubmFtZX1gIH0pXG4gICAgdHJ5IHtcbiAgICAgIGNvbnN0IHN0YXJ0ID0gRGF0ZS5ub3coKVxuICAgICAgYXdhaXQgaW5pdFRyYW5zYWN0aW9uKHJlcSlcbiAgICAgIGF3YWl0IG1pZ3JhdGlvbi51cCh7IHBheWxvYWQsIHJlcSB9KVxuICAgICAgYXdhaXQgcGF5bG9hZC5jcmVhdGUoe1xuICAgICAgICBjb2xsZWN0aW9uOiAncGF5bG9hZC1taWdyYXRpb25zJyxcbiAgICAgICAgZGF0YToge1xuICAgICAgICAgIG5hbWU6IG1pZ3JhdGlvbi5uYW1lLFxuICAgICAgICAgIGJhdGNoOiAxLFxuICAgICAgICB9LFxuICAgICAgICByZXEsXG4gICAgICB9KVxuXG4gICAgICBhd2FpdCBjb21taXRUcmFuc2FjdGlvbihyZXEpXG5cbiAgICAgIHBheWxvYWQubG9nZ2VyLmluZm8oeyBtc2c6IGBNaWdyYXRlZDogICR7bWlncmF0aW9uLm5hbWV9ICgke0RhdGUubm93KCkgLSBzdGFydH1tcylgIH0pXG4gICAgfSBjYXRjaCAoZXJyOiB1bmtub3duKSB7XG4gICAgICBhd2FpdCBraWxsVHJhbnNhY3Rpb24ocmVxKVxuICAgICAgcGF5bG9hZC5sb2dnZXIuZXJyb3Ioe1xuICAgICAgICBlcnIsXG4gICAgICAgIG1zZzogYEVycm9yIHJ1bm5pbmcgbWlncmF0aW9uICR7bWlncmF0aW9uLm5hbWV9LiBSb2xsaW5nIGJhY2suYCxcbiAgICAgIH0pXG4gICAgICB0aHJvdyBlcnJcbiAgICB9XG4gIH1cbn1cbiJdLCJuYW1lcyI6WyJtaWdyYXRlRnJlc2giLCJwYXlsb2FkIiwiY29uZmlybSIsImFjY2VwdFdhcm5pbmciLCJwcm9tcHRzIiwibmFtZSIsInR5cGUiLCJpbml0aWFsIiwibWVzc2FnZSIsIm9uQ2FuY2VsIiwicHJvY2VzcyIsImV4aXQiLCJsb2dnZXIiLCJpbmZvIiwibXNnIiwiY29ubmVjdGlvbiIsImRyb3BEYXRhYmFzZSIsIm1pZ3JhdGlvbkZpbGVzIiwicmVhZE1pZ3JhdGlvbkZpbGVzIiwiZGVidWciLCJsZW5ndGgiLCJyZXEiLCJtaWdyYXRpb24iLCJzdGFydCIsIkRhdGUiLCJub3ciLCJpbml0VHJhbnNhY3Rpb24iLCJ1cCIsImNyZWF0ZSIsImNvbGxlY3Rpb24iLCJkYXRhIiwiYmF0Y2giLCJjb21taXRUcmFuc2FjdGlvbiIsImVyciIsImtpbGxUcmFuc2FjdGlvbiIsImVycm9yIl0sIm1hcHBpbmdzIjoiOzs7OytCQWFzQkE7OztlQUFBQTs7OzBCQVhhO21DQUNEO2lDQUNGO2lDQUNBO2dFQUNaOzs7Ozs7QUFPYixlQUFlQTtJQUNwQixNQUFNLEVBQUVDLE9BQU8sRUFBRSxHQUFHLElBQUk7SUFFeEIsTUFBTSxFQUFFQyxTQUFTQyxhQUFhLEVBQUUsR0FBRyxNQUFNQyxJQUFBQSxnQkFBTyxFQUM5QztRQUNFQyxNQUFNO1FBQ05DLE1BQU07UUFDTkMsU0FBUztRQUNUQyxTQUFTLENBQUMsK0ZBQStGLENBQUM7SUFDNUcsR0FDQTtRQUNFQyxVQUFVO1lBQ1JDLFFBQVFDLElBQUksQ0FBQztRQUNmO0lBQ0Y7SUFHRixJQUFJLENBQUNSLGVBQWU7UUFDbEJPLFFBQVFDLElBQUksQ0FBQztJQUNmO0lBRUFWLFFBQVFXLE1BQU0sQ0FBQ0MsSUFBSSxDQUFDO1FBQ2xCQyxLQUFLLENBQUMsa0JBQWtCLENBQUM7SUFDM0I7SUFFQSxNQUFNLElBQUksQ0FBQ0MsVUFBVSxDQUFDQyxZQUFZO0lBRWxDLE1BQU1DLGlCQUFpQixNQUFNQyxJQUFBQSw0QkFBa0IsRUFBQztRQUFFakI7SUFBUTtJQUMxREEsUUFBUVcsTUFBTSxDQUFDTyxLQUFLLENBQUM7UUFDbkJMLEtBQUssQ0FBQyxNQUFNLEVBQUVHLGVBQWVHLE1BQU0sQ0FBQyxpQkFBaUIsQ0FBQztJQUN4RDtJQUVBLE1BQU1DLE1BQU07UUFBRXBCO0lBQVE7SUFFdEIscUJBQXFCO0lBQ3JCLEtBQUssTUFBTXFCLGFBQWFMLGVBQWdCO1FBQ3RDaEIsUUFBUVcsTUFBTSxDQUFDQyxJQUFJLENBQUM7WUFBRUMsS0FBSyxDQUFDLFdBQVcsRUFBRVEsVUFBVWpCLElBQUksQ0FBQyxDQUFDO1FBQUM7UUFDMUQsSUFBSTtZQUNGLE1BQU1rQixRQUFRQyxLQUFLQyxHQUFHO1lBQ3RCLE1BQU1DLElBQUFBLGdDQUFlLEVBQUNMO1lBQ3RCLE1BQU1DLFVBQVVLLEVBQUUsQ0FBQztnQkFBRTFCO2dCQUFTb0I7WUFBSTtZQUNsQyxNQUFNcEIsUUFBUTJCLE1BQU0sQ0FBQztnQkFDbkJDLFlBQVk7Z0JBQ1pDLE1BQU07b0JBQ0p6QixNQUFNaUIsVUFBVWpCLElBQUk7b0JBQ3BCMEIsT0FBTztnQkFDVDtnQkFDQVY7WUFDRjtZQUVBLE1BQU1XLElBQUFBLG9DQUFpQixFQUFDWDtZQUV4QnBCLFFBQVFXLE1BQU0sQ0FBQ0MsSUFBSSxDQUFDO2dCQUFFQyxLQUFLLENBQUMsV0FBVyxFQUFFUSxVQUFVakIsSUFBSSxDQUFDLEVBQUUsRUFBRW1CLEtBQUtDLEdBQUcsS0FBS0YsTUFBTSxHQUFHLENBQUM7WUFBQztRQUN0RixFQUFFLE9BQU9VLEtBQWM7WUFDckIsTUFBTUMsSUFBQUEsZ0NBQWUsRUFBQ2I7WUFDdEJwQixRQUFRVyxNQUFNLENBQUN1QixLQUFLLENBQUM7Z0JBQ25CRjtnQkFDQW5CLEtBQUssQ0FBQyx3QkFBd0IsRUFBRVEsVUFBVWpCLElBQUksQ0FBQyxlQUFlLENBQUM7WUFDakU7WUFDQSxNQUFNNEI7UUFDUjtJQUNGO0FBQ0YifQ==
86
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uL3NyYy9taWdyYXRlRnJlc2gudHMiXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHR5cGUgeyBQYXlsb2FkUmVxdWVzdCB9IGZyb20gJ3BheWxvYWQvdHlwZXMnXG5cbmltcG9ydCB7IHJlYWRNaWdyYXRpb25GaWxlcyB9IGZyb20gJ3BheWxvYWQvZGF0YWJhc2UnXG5pbXBvcnQgeyBjb21taXRUcmFuc2FjdGlvbiB9IGZyb20gJ3BheWxvYWQvZGlzdC91dGlsaXRpZXMvY29tbWl0VHJhbnNhY3Rpb24nXG5pbXBvcnQgeyBpbml0VHJhbnNhY3Rpb24gfSBmcm9tICdwYXlsb2FkL2Rpc3QvdXRpbGl0aWVzL2luaXRUcmFuc2FjdGlvbidcbmltcG9ydCB7IGtpbGxUcmFuc2FjdGlvbiB9IGZyb20gJ3BheWxvYWQvZGlzdC91dGlsaXRpZXMva2lsbFRyYW5zYWN0aW9uJ1xuaW1wb3J0IHByb21wdHMgZnJvbSAncHJvbXB0cydcblxuaW1wb3J0IHR5cGUgeyBNb25nb29zZUFkYXB0ZXIgfSBmcm9tICcuJ1xuXG4vKipcbiAqIERyb3AgdGhlIGN1cnJlbnQgZGF0YWJhc2UgYW5kIHJ1biBhbGwgbWlncmF0ZSB1cCBmdW5jdGlvbnNcbiAqL1xuZXhwb3J0IGFzeW5jIGZ1bmN0aW9uIG1pZ3JhdGVGcmVzaChcbiAgdGhpczogTW9uZ29vc2VBZGFwdGVyLFxuICB7IGZvcmNlQWNjZXB0V2FybmluZyA9IGZhbHNlIH06IHsgZm9yY2VBY2NlcHRXYXJuaW5nPzogYm9vbGVhbiB9LFxuKTogUHJvbWlzZTx2b2lkPiB7XG4gIGNvbnN0IHsgcGF5bG9hZCB9ID0gdGhpc1xuXG4gIGlmICghZm9yY2VBY2NlcHRXYXJuaW5nKSB7XG4gICAgY29uc3QgeyBjb25maXJtOiBhY2NlcHRXYXJuaW5nIH0gPSBhd2FpdCBwcm9tcHRzKFxuICAgICAge1xuICAgICAgICBuYW1lOiAnY29uZmlybScsXG4gICAgICAgIHR5cGU6ICdjb25maXJtJyxcbiAgICAgICAgaW5pdGlhbDogZmFsc2UsXG4gICAgICAgIG1lc3NhZ2U6IGBXQVJOSU5HOiBUaGlzIHdpbGwgZHJvcCB5b3VyIGRhdGFiYXNlIGFuZCBydW4gYWxsIG1pZ3JhdGlvbnMuIEFyZSB5b3Ugc3VyZSB5b3Ugd2FudCB0byBwcm9jZWVkP2AsXG4gICAgICB9LFxuICAgICAge1xuICAgICAgICBvbkNhbmNlbDogKCkgPT4ge1xuICAgICAgICAgIHByb2Nlc3MuZXhpdCgwKVxuICAgICAgICB9LFxuICAgICAgfSxcbiAgICApXG5cbiAgICBpZiAoIWFjY2VwdFdhcm5pbmcpIHtcbiAgICAgIHByb2Nlc3MuZXhpdCgwKVxuICAgIH1cbiAgfVxuXG4gIHBheWxvYWQubG9nZ2VyLmluZm8oe1xuICAgIG1zZzogYERyb3BwaW5nIGRhdGFiYXNlLmAsXG4gIH0pXG5cbiAgYXdhaXQgdGhpcy5jb25uZWN0aW9uLmRyb3BEYXRhYmFzZSgpXG5cbiAgY29uc3QgbWlncmF0aW9uRmlsZXMgPSBhd2FpdCByZWFkTWlncmF0aW9uRmlsZXMoeyBwYXlsb2FkIH0pXG4gIHBheWxvYWQubG9nZ2VyLmRlYnVnKHtcbiAgICBtc2c6IGBGb3VuZCAke21pZ3JhdGlvbkZpbGVzLmxlbmd0aH0gbWlncmF0aW9uIGZpbGVzLmAsXG4gIH0pXG5cbiAgY29uc3QgcmVxID0geyBwYXlsb2FkIH0gYXMgUGF5bG9hZFJlcXVlc3RcblxuICAvLyBSdW4gYWxsIG1pZ3JhdGUgdXBcbiAgZm9yIChjb25zdCBtaWdyYXRpb24gb2YgbWlncmF0aW9uRmlsZXMpIHtcbiAgICBwYXlsb2FkLmxvZ2dlci5pbmZvKHsgbXNnOiBgTWlncmF0aW5nOiAke21pZ3JhdGlvbi5uYW1lfWAgfSlcbiAgICB0cnkge1xuICAgICAgY29uc3Qgc3RhcnQgPSBEYXRlLm5vdygpXG4gICAgICBhd2FpdCBpbml0VHJhbnNhY3Rpb24ocmVxKVxuICAgICAgYXdhaXQgbWlncmF0aW9uLnVwKHsgcGF5bG9hZCwgcmVxIH0pXG4gICAgICBhd2FpdCBwYXlsb2FkLmNyZWF0ZSh7XG4gICAgICAgIGNvbGxlY3Rpb246ICdwYXlsb2FkLW1pZ3JhdGlvbnMnLFxuICAgICAgICBkYXRhOiB7XG4gICAgICAgICAgbmFtZTogbWlncmF0aW9uLm5hbWUsXG4gICAgICAgICAgYmF0Y2g6IDEsXG4gICAgICAgIH0sXG4gICAgICAgIHJlcSxcbiAgICAgIH0pXG5cbiAgICAgIGF3YWl0IGNvbW1pdFRyYW5zYWN0aW9uKHJlcSlcblxuICAgICAgcGF5bG9hZC5sb2dnZXIuaW5mbyh7IG1zZzogYE1pZ3JhdGVkOiAgJHttaWdyYXRpb24ubmFtZX0gKCR7RGF0ZS5ub3coKSAtIHN0YXJ0fW1zKWAgfSlcbiAgICB9IGNhdGNoIChlcnI6IHVua25vd24pIHtcbiAgICAgIGF3YWl0IGtpbGxUcmFuc2FjdGlvbihyZXEpXG4gICAgICBwYXlsb2FkLmxvZ2dlci5lcnJvcih7XG4gICAgICAgIGVycixcbiAgICAgICAgbXNnOiBgRXJyb3IgcnVubmluZyBtaWdyYXRpb24gJHttaWdyYXRpb24ubmFtZX0uIFJvbGxpbmcgYmFjay5gLFxuICAgICAgfSlcbiAgICAgIHRocm93IGVyclxuICAgIH1cbiAgfVxufVxuIl0sIm5hbWVzIjpbIm1pZ3JhdGVGcmVzaCIsImZvcmNlQWNjZXB0V2FybmluZyIsInBheWxvYWQiLCJjb25maXJtIiwiYWNjZXB0V2FybmluZyIsInByb21wdHMiLCJuYW1lIiwidHlwZSIsImluaXRpYWwiLCJtZXNzYWdlIiwib25DYW5jZWwiLCJwcm9jZXNzIiwiZXhpdCIsImxvZ2dlciIsImluZm8iLCJtc2ciLCJjb25uZWN0aW9uIiwiZHJvcERhdGFiYXNlIiwibWlncmF0aW9uRmlsZXMiLCJyZWFkTWlncmF0aW9uRmlsZXMiLCJkZWJ1ZyIsImxlbmd0aCIsInJlcSIsIm1pZ3JhdGlvbiIsInN0YXJ0IiwiRGF0ZSIsIm5vdyIsImluaXRUcmFuc2FjdGlvbiIsInVwIiwiY3JlYXRlIiwiY29sbGVjdGlvbiIsImRhdGEiLCJiYXRjaCIsImNvbW1pdFRyYW5zYWN0aW9uIiwiZXJyIiwia2lsbFRyYW5zYWN0aW9uIiwiZXJyb3IiXSwibWFwcGluZ3MiOiI7Ozs7K0JBYXNCQTs7O2VBQUFBOzs7MEJBWGE7bUNBQ0Q7aUNBQ0Y7aUNBQ0E7Z0VBQ1o7Ozs7OztBQU9iLGVBQWVBLGFBRXBCLEVBQUVDLHFCQUFxQixLQUFLLEVBQW9DO0lBRWhFLE1BQU0sRUFBRUMsT0FBTyxFQUFFLEdBQUcsSUFBSTtJQUV4QixJQUFJLENBQUNELG9CQUFvQjtRQUN2QixNQUFNLEVBQUVFLFNBQVNDLGFBQWEsRUFBRSxHQUFHLE1BQU1DLElBQUFBLGdCQUFPLEVBQzlDO1lBQ0VDLE1BQU07WUFDTkMsTUFBTTtZQUNOQyxTQUFTO1lBQ1RDLFNBQVMsQ0FBQywrRkFBK0YsQ0FBQztRQUM1RyxHQUNBO1lBQ0VDLFVBQVU7Z0JBQ1JDLFFBQVFDLElBQUksQ0FBQztZQUNmO1FBQ0Y7UUFHRixJQUFJLENBQUNSLGVBQWU7WUFDbEJPLFFBQVFDLElBQUksQ0FBQztRQUNmO0lBQ0Y7SUFFQVYsUUFBUVcsTUFBTSxDQUFDQyxJQUFJLENBQUM7UUFDbEJDLEtBQUssQ0FBQyxrQkFBa0IsQ0FBQztJQUMzQjtJQUVBLE1BQU0sSUFBSSxDQUFDQyxVQUFVLENBQUNDLFlBQVk7SUFFbEMsTUFBTUMsaUJBQWlCLE1BQU1DLElBQUFBLDRCQUFrQixFQUFDO1FBQUVqQjtJQUFRO0lBQzFEQSxRQUFRVyxNQUFNLENBQUNPLEtBQUssQ0FBQztRQUNuQkwsS0FBSyxDQUFDLE1BQU0sRUFBRUcsZUFBZUcsTUFBTSxDQUFDLGlCQUFpQixDQUFDO0lBQ3hEO0lBRUEsTUFBTUMsTUFBTTtRQUFFcEI7SUFBUTtJQUV0QixxQkFBcUI7SUFDckIsS0FBSyxNQUFNcUIsYUFBYUwsZUFBZ0I7UUFDdENoQixRQUFRVyxNQUFNLENBQUNDLElBQUksQ0FBQztZQUFFQyxLQUFLLENBQUMsV0FBVyxFQUFFUSxVQUFVakIsSUFBSSxDQUFDLENBQUM7UUFBQztRQUMxRCxJQUFJO1lBQ0YsTUFBTWtCLFFBQVFDLEtBQUtDLEdBQUc7WUFDdEIsTUFBTUMsSUFBQUEsZ0NBQWUsRUFBQ0w7WUFDdEIsTUFBTUMsVUFBVUssRUFBRSxDQUFDO2dCQUFFMUI7Z0JBQVNvQjtZQUFJO1lBQ2xDLE1BQU1wQixRQUFRMkIsTUFBTSxDQUFDO2dCQUNuQkMsWUFBWTtnQkFDWkMsTUFBTTtvQkFDSnpCLE1BQU1pQixVQUFVakIsSUFBSTtvQkFDcEIwQixPQUFPO2dCQUNUO2dCQUNBVjtZQUNGO1lBRUEsTUFBTVcsSUFBQUEsb0NBQWlCLEVBQUNYO1lBRXhCcEIsUUFBUVcsTUFBTSxDQUFDQyxJQUFJLENBQUM7Z0JBQUVDLEtBQUssQ0FBQyxXQUFXLEVBQUVRLFVBQVVqQixJQUFJLENBQUMsRUFBRSxFQUFFbUIsS0FBS0MsR0FBRyxLQUFLRixNQUFNLEdBQUcsQ0FBQztZQUFDO1FBQ3RGLEVBQUUsT0FBT1UsS0FBYztZQUNyQixNQUFNQyxJQUFBQSxnQ0FBZSxFQUFDYjtZQUN0QnBCLFFBQVFXLE1BQU0sQ0FBQ3VCLEtBQUssQ0FBQztnQkFDbkJGO2dCQUNBbkIsS0FBSyxDQUFDLHdCQUF3QixFQUFFUSxVQUFVakIsSUFBSSxDQUFDLGVBQWUsQ0FBQztZQUNqRTtZQUNBLE1BQU00QjtRQUNSO0lBQ0Y7QUFDRiJ9
@@ -1 +1 @@
1
- {"version":3,"file":"sanitizeQueryValue.d.ts","sourceRoot":"","sources":["../../src/queries/sanitizeQueryValue.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,KAAK,EAAE,UAAU,EAAE,MAAM,eAAe,CAAA;AAKtD,KAAK,sBAAsB,GAAG;IAC5B,KAAK,EAAE,KAAK,GAAG,UAAU,CAAA;IACzB,WAAW,EAAE,OAAO,CAAA;IACpB,QAAQ,EAAE,MAAM,CAAA;IAChB,IAAI,EAAE,MAAM,CAAA;IACZ,GAAG,EAAE,GAAG,CAAA;CACT,CAAA;AAED,eAAO,MAAM,kBAAkB,iDAM5B,sBAAsB;eACZ,MAAM;eACN,OAAO;UACZ,OAAO;CA2Id,CAAA"}
1
+ {"version":3,"file":"sanitizeQueryValue.d.ts","sourceRoot":"","sources":["../../src/queries/sanitizeQueryValue.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,KAAK,EAAE,UAAU,EAAE,MAAM,eAAe,CAAA;AAKtD,KAAK,sBAAsB,GAAG;IAC5B,KAAK,EAAE,KAAK,GAAG,UAAU,CAAA;IACzB,WAAW,EAAE,OAAO,CAAA;IACpB,QAAQ,EAAE,MAAM,CAAA;IAChB,IAAI,EAAE,MAAM,CAAA;IACZ,GAAG,EAAE,GAAG,CAAA;CACT,CAAA;AAED,eAAO,MAAM,kBAAkB,iDAM5B,sBAAsB;eACZ,MAAM;eACN,OAAO;UACZ,OAAO;CA6Jd,CAAA"}
@@ -71,7 +71,7 @@ const sanitizeQueryValue = ({ field, hasCustomID, operator, path, val })=>{
71
71
  formattedValue = null;
72
72
  }
73
73
  // Object equality requires the value to be the first key in the object that is being queried.
74
- if (operator === 'equals' && typeof formattedValue === 'object' && formattedValue.value && formattedValue.relationTo) {
74
+ if (operator === 'equals' && formattedValue && typeof formattedValue === 'object' && formattedValue.value && formattedValue.relationTo) {
75
75
  return {
76
76
  rawQuery: {
77
77
  $and: [
@@ -150,6 +150,48 @@ const sanitizeQueryValue = ({ field, hasCustomID, operator, path, val })=>{
150
150
  }
151
151
  if (operator === 'exists') {
152
152
  formattedValue = formattedValue === 'true' || formattedValue === true;
153
+ // Clearable fields
154
+ if ([
155
+ 'relationship',
156
+ 'select',
157
+ 'upload'
158
+ ].includes(field.type)) {
159
+ if (formattedValue) {
160
+ return {
161
+ rawQuery: {
162
+ $and: [
163
+ {
164
+ [path]: {
165
+ $exists: true
166
+ }
167
+ },
168
+ {
169
+ [path]: {
170
+ $ne: null
171
+ }
172
+ }
173
+ ]
174
+ }
175
+ };
176
+ } else {
177
+ return {
178
+ rawQuery: {
179
+ $or: [
180
+ {
181
+ [path]: {
182
+ $exists: false
183
+ }
184
+ },
185
+ {
186
+ [path]: {
187
+ $eq: null
188
+ }
189
+ }
190
+ ]
191
+ }
192
+ };
193
+ }
194
+ }
153
195
  }
154
196
  return {
155
197
  operator: formattedOperator,
@@ -157,4 +199,4 @@ const sanitizeQueryValue = ({ field, hasCustomID, operator, path, val })=>{
157
199
  };
158
200
  };
159
201
 
160
- //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../src/queries/sanitizeQueryValue.ts"],"sourcesContent":["import type { Field, TabAsField } from 'payload/types'\n\nimport mongoose from 'mongoose'\nimport { createArrayFromCommaDelineated } from 'payload/utilities'\n\ntype SanitizeQueryValueArgs = {\n  field: Field | TabAsField\n  hasCustomID: boolean\n  operator: string\n  path: string\n  val: any\n}\n\nexport const sanitizeQueryValue = ({\n  field,\n  hasCustomID,\n  operator,\n  path,\n  val,\n}: SanitizeQueryValueArgs): {\n  operator?: string\n  rawQuery?: unknown\n  val?: unknown\n} => {\n  let formattedValue = val\n  let formattedOperator = operator\n\n  // Disregard invalid _ids\n  if (path === '_id' && typeof val === 'string' && val.split(',').length === 1) {\n    if (!hasCustomID) {\n      const isValid = mongoose.Types.ObjectId.isValid(val)\n\n      if (!isValid) {\n        return { operator: formattedOperator, val: undefined }\n      }\n    }\n\n    if (field.type === 'number') {\n      const parsedNumber = parseFloat(val)\n\n      if (Number.isNaN(parsedNumber)) {\n        return { operator: formattedOperator, val: undefined }\n      }\n    }\n  }\n\n  // Cast incoming values as proper searchable types\n  if (field.type === 'checkbox' && typeof val === 'string') {\n    if (val.toLowerCase() === 'true') formattedValue = true\n    if (val.toLowerCase() === 'false') formattedValue = false\n  }\n\n  if (['all', 'in', 'not_in'].includes(operator) && typeof formattedValue === 'string') {\n    formattedValue = createArrayFromCommaDelineated(formattedValue)\n\n    if (field.type === 'number') {\n      formattedValue = formattedValue.map((arrayVal) => parseFloat(arrayVal))\n    }\n  }\n\n  if (field.type === 'number' && typeof formattedValue === 'string') {\n    formattedValue = Number(val)\n  }\n\n  if (field.type === 'date' && typeof val === 'string') {\n    formattedValue = new Date(val)\n    if (Number.isNaN(Date.parse(formattedValue))) {\n      return undefined\n    }\n  }\n\n  if (['relationship', 'upload'].includes(field.type)) {\n    if (val === 'null') {\n      formattedValue = null\n    }\n\n    // Object equality requires the value to be the first key in the object that is being queried.\n    if (\n      operator === 'equals' &&\n      typeof formattedValue === 'object' &&\n      formattedValue.value &&\n      formattedValue.relationTo\n    ) {\n      return {\n        rawQuery: {\n          $and: [\n            { [`${path}.value`]: { $eq: formattedValue.value } },\n            { [`${path}.relationTo`]: { $eq: formattedValue.relationTo } },\n          ],\n        },\n      }\n    }\n\n    if (operator === 'in' && Array.isArray(formattedValue)) {\n      formattedValue = formattedValue.reduce((formattedValues, inVal) => {\n        const newValues = [inVal]\n        if (mongoose.Types.ObjectId.isValid(inVal))\n          newValues.push(new mongoose.Types.ObjectId(inVal))\n\n        const parsedNumber = parseFloat(inVal)\n        if (!Number.isNaN(parsedNumber)) newValues.push(parsedNumber)\n\n        return [...formattedValues, ...newValues]\n      }, [])\n    }\n  }\n\n  // Set up specific formatting necessary by operators\n\n  if (operator === 'near') {\n    let lng\n    let lat\n    let maxDistance\n    let minDistance\n\n    if (Array.isArray(formattedValue)) {\n      ;[lng, lat, maxDistance, minDistance] = formattedValue\n    }\n\n    if (typeof formattedValue === 'string') {\n      ;[lng, lat, maxDistance, minDistance] = createArrayFromCommaDelineated(formattedValue)\n    }\n\n    if (lng == null || lat == null || (maxDistance == null && minDistance == null)) {\n      formattedValue = undefined\n    } else {\n      formattedValue = {\n        $geometry: { type: 'Point', coordinates: [parseFloat(lng), parseFloat(lat)] },\n      }\n\n      if (maxDistance) formattedValue.$maxDistance = parseFloat(maxDistance)\n      if (minDistance) formattedValue.$minDistance = parseFloat(minDistance)\n    }\n  }\n\n  if (operator === 'within' || operator === 'intersects') {\n    formattedValue = {\n      $geometry: formattedValue,\n    }\n  }\n\n  if (path !== '_id' || (path === '_id' && hasCustomID && field.type === 'text')) {\n    if (operator === 'contains') {\n      formattedValue = { $options: 'i', $regex: formattedValue }\n    }\n  }\n\n  if (\n    (path === '_id' || path === 'parent') &&\n    operator === 'like' &&\n    formattedValue.length === 24 &&\n    !hasCustomID\n  ) {\n    formattedOperator = 'equals'\n  }\n\n  if (operator === 'exists') {\n    formattedValue = formattedValue === 'true' || formattedValue === true\n  }\n\n  return { operator: formattedOperator, val: formattedValue }\n}\n"],"names":["sanitizeQueryValue","field","hasCustomID","operator","path","val","formattedValue","formattedOperator","split","length","isValid","mongoose","Types","ObjectId","undefined","type","parsedNumber","parseFloat","Number","isNaN","toLowerCase","includes","createArrayFromCommaDelineated","map","arrayVal","Date","parse","value","relationTo","rawQuery","$and","$eq","Array","isArray","reduce","formattedValues","inVal","newValues","push","lng","lat","maxDistance","minDistance","$geometry","coordinates","$maxDistance","$minDistance","$options","$regex"],"mappings":"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"}
202
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../src/queries/sanitizeQueryValue.ts"],"sourcesContent":["import type { Field, TabAsField } from 'payload/types'\n\nimport mongoose from 'mongoose'\nimport { createArrayFromCommaDelineated } from 'payload/utilities'\n\ntype SanitizeQueryValueArgs = {\n  field: Field | TabAsField\n  hasCustomID: boolean\n  operator: string\n  path: string\n  val: any\n}\n\nexport const sanitizeQueryValue = ({\n  field,\n  hasCustomID,\n  operator,\n  path,\n  val,\n}: SanitizeQueryValueArgs): {\n  operator?: string\n  rawQuery?: unknown\n  val?: unknown\n} => {\n  let formattedValue = val\n  let formattedOperator = operator\n\n  // Disregard invalid _ids\n  if (path === '_id' && typeof val === 'string' && val.split(',').length === 1) {\n    if (!hasCustomID) {\n      const isValid = mongoose.Types.ObjectId.isValid(val)\n\n      if (!isValid) {\n        return { operator: formattedOperator, val: undefined }\n      }\n    }\n\n    if (field.type === 'number') {\n      const parsedNumber = parseFloat(val)\n\n      if (Number.isNaN(parsedNumber)) {\n        return { operator: formattedOperator, val: undefined }\n      }\n    }\n  }\n\n  // Cast incoming values as proper searchable types\n  if (field.type === 'checkbox' && typeof val === 'string') {\n    if (val.toLowerCase() === 'true') formattedValue = true\n    if (val.toLowerCase() === 'false') formattedValue = false\n  }\n\n  if (['all', 'in', 'not_in'].includes(operator) && typeof formattedValue === 'string') {\n    formattedValue = createArrayFromCommaDelineated(formattedValue)\n\n    if (field.type === 'number') {\n      formattedValue = formattedValue.map((arrayVal) => parseFloat(arrayVal))\n    }\n  }\n\n  if (field.type === 'number' && typeof formattedValue === 'string') {\n    formattedValue = Number(val)\n  }\n\n  if (field.type === 'date' && typeof val === 'string') {\n    formattedValue = new Date(val)\n    if (Number.isNaN(Date.parse(formattedValue))) {\n      return undefined\n    }\n  }\n\n  if (['relationship', 'upload'].includes(field.type)) {\n    if (val === 'null') {\n      formattedValue = null\n    }\n\n    // Object equality requires the value to be the first key in the object that is being queried.\n    if (\n      operator === 'equals' &&\n      formattedValue &&\n      typeof formattedValue === 'object' &&\n      formattedValue.value &&\n      formattedValue.relationTo\n    ) {\n      return {\n        rawQuery: {\n          $and: [\n            { [`${path}.value`]: { $eq: formattedValue.value } },\n            { [`${path}.relationTo`]: { $eq: formattedValue.relationTo } },\n          ],\n        },\n      }\n    }\n\n    if (operator === 'in' && Array.isArray(formattedValue)) {\n      formattedValue = formattedValue.reduce((formattedValues, inVal) => {\n        const newValues = [inVal]\n        if (mongoose.Types.ObjectId.isValid(inVal))\n          newValues.push(new mongoose.Types.ObjectId(inVal))\n\n        const parsedNumber = parseFloat(inVal)\n        if (!Number.isNaN(parsedNumber)) newValues.push(parsedNumber)\n\n        return [...formattedValues, ...newValues]\n      }, [])\n    }\n  }\n\n  // Set up specific formatting necessary by operators\n\n  if (operator === 'near') {\n    let lng\n    let lat\n    let maxDistance\n    let minDistance\n\n    if (Array.isArray(formattedValue)) {\n      ;[lng, lat, maxDistance, minDistance] = formattedValue\n    }\n\n    if (typeof formattedValue === 'string') {\n      ;[lng, lat, maxDistance, minDistance] = createArrayFromCommaDelineated(formattedValue)\n    }\n\n    if (lng == null || lat == null || (maxDistance == null && minDistance == null)) {\n      formattedValue = undefined\n    } else {\n      formattedValue = {\n        $geometry: { type: 'Point', coordinates: [parseFloat(lng), parseFloat(lat)] },\n      }\n\n      if (maxDistance) formattedValue.$maxDistance = parseFloat(maxDistance)\n      if (minDistance) formattedValue.$minDistance = parseFloat(minDistance)\n    }\n  }\n\n  if (operator === 'within' || operator === 'intersects') {\n    formattedValue = {\n      $geometry: formattedValue,\n    }\n  }\n\n  if (path !== '_id' || (path === '_id' && hasCustomID && field.type === 'text')) {\n    if (operator === 'contains') {\n      formattedValue = { $options: 'i', $regex: formattedValue }\n    }\n  }\n\n  if (\n    (path === '_id' || path === 'parent') &&\n    operator === 'like' &&\n    formattedValue.length === 24 &&\n    !hasCustomID\n  ) {\n    formattedOperator = 'equals'\n  }\n\n  if (operator === 'exists') {\n    formattedValue = formattedValue === 'true' || formattedValue === true\n\n    // Clearable fields\n    if (['relationship', 'select', 'upload'].includes(field.type)) {\n      if (formattedValue) {\n        return {\n          rawQuery: {\n            $and: [{ [path]: { $exists: true } }, { [path]: { $ne: null } }],\n          },\n        }\n      } else {\n        return {\n          rawQuery: {\n            $or: [{ [path]: { $exists: false } }, { [path]: { $eq: null } }],\n          },\n        }\n      }\n    }\n  }\n\n  return { operator: formattedOperator, val: formattedValue }\n}\n"],"names":["sanitizeQueryValue","field","hasCustomID","operator","path","val","formattedValue","formattedOperator","split","length","isValid","mongoose","Types","ObjectId","undefined","type","parsedNumber","parseFloat","Number","isNaN","toLowerCase","includes","createArrayFromCommaDelineated","map","arrayVal","Date","parse","value","relationTo","rawQuery","$and","$eq","Array","isArray","reduce","formattedValues","inVal","newValues","push","lng","lat","maxDistance","minDistance","$geometry","coordinates","$maxDistance","$minDistance","$options","$regex","$exists","$ne","$or"],"mappings":"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"}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@payloadcms/db-mongodb",
3
- "version": "1.3.2",
3
+ "version": "1.4.1",
4
4
  "description": "The officially supported MongoDB database adapter for Payload",
5
5
  "repository": "https://github.com/payloadcms/payload",
6
6
  "license": "MIT",
@@ -27,7 +27,7 @@
27
27
  "@types/mongoose-aggregate-paginate-v2": "1.0.9",
28
28
  "mongodb": "4.17.1",
29
29
  "mongodb-memory-server": "^9",
30
- "payload": "2.8.2",
30
+ "payload": "2.10.1",
31
31
  "@payloadcms/eslint-config": "1.1.1"
32
32
  },
33
33
  "peerDependencies": {