parse-server 6.3.0-beta.1 → 6.3.0

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.
@@ -66,9 +66,16 @@ class PushController {
66
66
 
67
67
  // Force filtering on only valid device tokens
68
68
  const updateWhere = (0, _utils.applyDeviceTokenExists)(where);
69
- badgeUpdate = () => {
69
+ badgeUpdate = async () => {
70
70
  // Build a real RestQuery so we can use it in RestWrite
71
- const restQuery = new _RestQuery.default(config, (0, _Auth.master)(config), '_Installation', updateWhere);
71
+ const restQuery = await (0, _RestQuery.default)({
72
+ method: _RestQuery.default.Method.find,
73
+ config,
74
+ runBeforeFind: false,
75
+ auth: (0, _Auth.master)(config),
76
+ className: '_Installation',
77
+ restWhere: updateWhere
78
+ });
72
79
  return restQuery.buildRestWhere().then(() => {
73
80
  const write = new _RestWrite.default(config, (0, _Auth.master)(config), '_Installation', restQuery.restWhere, restUpdate);
74
81
  write.runOptions.many = true;
@@ -215,4 +222,4 @@ class PushController {
215
222
  exports.PushController = PushController;
216
223
  var _default = PushController;
217
224
  exports.default = _default;
218
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["PushController","sendPush","body","where","config","auth","onPushStatusSaved","now","Date","hasPushSupport","Parse","Error","PUSH_MISCONFIGURED","expiration_time","getExpirationTime","expiration_interval","getExpirationInterval","Object","prototype","hasOwnProperty","call","ttlMs","valueOf","pushTime","getPushTime","date","formatPushTime","badgeUpdate","Promise","resolve","data","badge","restUpdate","toLowerCase","__op","amount","Number","updateWhere","applyDeviceTokenExists","restQuery","RestQuery","master","buildRestWhere","then","write","RestWrite","restWhere","runOptions","many","execute","pushStatus","pushStatusHandler","setInitial","objectId","audience_id","audienceId","updateAudience","lastUsed","__type","iso","toISOString","timesUsed","hasPushScheduledSupport","pushControllerQueue","enqueue","catch","err","fail","hasExpirationTime","expirationTimeParam","expirationTime","isFinite","hasExpirationInterval","expirationIntervalParam","hasPushTime","pushTimeParam","isLocalTime","pushTimeHasTimezoneComponent","offsetPattern","indexOf","length","test","isoString","substring"],"sources":["../../src/Controllers/PushController.js"],"sourcesContent":["import { Parse } from 'parse/node';\nimport RestQuery from '../RestQuery';\nimport RestWrite from '../RestWrite';\nimport { master } from '../Auth';\nimport { pushStatusHandler } from '../StatusHandler';\nimport { applyDeviceTokenExists } from '../Push/utils';\n\nexport class PushController {\n  sendPush(body = {}, where = {}, config, auth, onPushStatusSaved = () => {}, now = new Date()) {\n    if (!config.hasPushSupport) {\n      throw new Parse.Error(Parse.Error.PUSH_MISCONFIGURED, 'Missing push configuration');\n    }\n\n    // Replace the expiration_time and push_time with a valid Unix epoch milliseconds time\n    body.expiration_time = PushController.getExpirationTime(body);\n    body.expiration_interval = PushController.getExpirationInterval(body);\n    if (body.expiration_time && body.expiration_interval) {\n      throw new Parse.Error(\n        Parse.Error.PUSH_MISCONFIGURED,\n        'Both expiration_time and expiration_interval cannot be set'\n      );\n    }\n\n    // Immediate push\n    if (body.expiration_interval && !Object.prototype.hasOwnProperty.call(body, 'push_time')) {\n      const ttlMs = body.expiration_interval * 1000;\n      body.expiration_time = new Date(now.valueOf() + ttlMs).valueOf();\n    }\n\n    const pushTime = PushController.getPushTime(body);\n    if (pushTime && pushTime.date !== 'undefined') {\n      body['push_time'] = PushController.formatPushTime(pushTime);\n    }\n\n    // TODO: If the req can pass the checking, we return immediately instead of waiting\n    // pushes to be sent. We probably change this behaviour in the future.\n    let badgeUpdate = () => {\n      return Promise.resolve();\n    };\n\n    if (body.data && body.data.badge) {\n      const badge = body.data.badge;\n      let restUpdate = {};\n      if (typeof badge == 'string' && badge.toLowerCase() === 'increment') {\n        restUpdate = { badge: { __op: 'Increment', amount: 1 } };\n      } else if (\n        typeof badge == 'object' &&\n        typeof badge.__op == 'string' &&\n        badge.__op.toLowerCase() == 'increment' &&\n        Number(badge.amount)\n      ) {\n        restUpdate = { badge: { __op: 'Increment', amount: badge.amount } };\n      } else if (Number(badge)) {\n        restUpdate = { badge: badge };\n      } else {\n        throw \"Invalid value for badge, expected number or 'Increment' or {increment: number}\";\n      }\n\n      // Force filtering on only valid device tokens\n      const updateWhere = applyDeviceTokenExists(where);\n      badgeUpdate = () => {\n        // Build a real RestQuery so we can use it in RestWrite\n        const restQuery = new RestQuery(config, master(config), '_Installation', updateWhere);\n        return restQuery.buildRestWhere().then(() => {\n          const write = new RestWrite(\n            config,\n            master(config),\n            '_Installation',\n            restQuery.restWhere,\n            restUpdate\n          );\n          write.runOptions.many = true;\n          return write.execute();\n        });\n      };\n    }\n    const pushStatus = pushStatusHandler(config);\n    return Promise.resolve()\n      .then(() => {\n        return pushStatus.setInitial(body, where);\n      })\n      .then(() => {\n        onPushStatusSaved(pushStatus.objectId);\n        return badgeUpdate();\n      })\n      .then(() => {\n        // Update audience lastUsed and timesUsed\n        if (body.audience_id) {\n          const audienceId = body.audience_id;\n\n          var updateAudience = {\n            lastUsed: { __type: 'Date', iso: new Date().toISOString() },\n            timesUsed: { __op: 'Increment', amount: 1 },\n          };\n          const write = new RestWrite(\n            config,\n            master(config),\n            '_Audience',\n            { objectId: audienceId },\n            updateAudience\n          );\n          write.execute();\n        }\n        // Don't wait for the audience update promise to resolve.\n        return Promise.resolve();\n      })\n      .then(() => {\n        if (\n          Object.prototype.hasOwnProperty.call(body, 'push_time') &&\n          config.hasPushScheduledSupport\n        ) {\n          return Promise.resolve();\n        }\n        return config.pushControllerQueue.enqueue(body, where, config, auth, pushStatus);\n      })\n      .catch(err => {\n        return pushStatus.fail(err).then(() => {\n          throw err;\n        });\n      });\n  }\n\n  /**\n   * Get expiration time from the request body.\n   * @param {Object} request A request object\n   * @returns {Number|undefined} The expiration time if it exists in the request\n   */\n  static getExpirationTime(body = {}) {\n    var hasExpirationTime = Object.prototype.hasOwnProperty.call(body, 'expiration_time');\n    if (!hasExpirationTime) {\n      return;\n    }\n    var expirationTimeParam = body['expiration_time'];\n    var expirationTime;\n    if (typeof expirationTimeParam === 'number') {\n      expirationTime = new Date(expirationTimeParam * 1000);\n    } else if (typeof expirationTimeParam === 'string') {\n      expirationTime = new Date(expirationTimeParam);\n    } else {\n      throw new Parse.Error(\n        Parse.Error.PUSH_MISCONFIGURED,\n        body['expiration_time'] + ' is not valid time.'\n      );\n    }\n    // Check expirationTime is valid or not, if it is not valid, expirationTime is NaN\n    if (!isFinite(expirationTime)) {\n      throw new Parse.Error(\n        Parse.Error.PUSH_MISCONFIGURED,\n        body['expiration_time'] + ' is not valid time.'\n      );\n    }\n    return expirationTime.valueOf();\n  }\n\n  static getExpirationInterval(body = {}) {\n    const hasExpirationInterval = Object.prototype.hasOwnProperty.call(body, 'expiration_interval');\n    if (!hasExpirationInterval) {\n      return;\n    }\n\n    var expirationIntervalParam = body['expiration_interval'];\n    if (typeof expirationIntervalParam !== 'number' || expirationIntervalParam <= 0) {\n      throw new Parse.Error(\n        Parse.Error.PUSH_MISCONFIGURED,\n        `expiration_interval must be a number greater than 0`\n      );\n    }\n    return expirationIntervalParam;\n  }\n\n  /**\n   * Get push time from the request body.\n   * @param {Object} request A request object\n   * @returns {Number|undefined} The push time if it exists in the request\n   */\n  static getPushTime(body = {}) {\n    var hasPushTime = Object.prototype.hasOwnProperty.call(body, 'push_time');\n    if (!hasPushTime) {\n      return;\n    }\n    var pushTimeParam = body['push_time'];\n    var date;\n    var isLocalTime = true;\n\n    if (typeof pushTimeParam === 'number') {\n      date = new Date(pushTimeParam * 1000);\n    } else if (typeof pushTimeParam === 'string') {\n      isLocalTime = !PushController.pushTimeHasTimezoneComponent(pushTimeParam);\n      date = new Date(pushTimeParam);\n    } else {\n      throw new Parse.Error(\n        Parse.Error.PUSH_MISCONFIGURED,\n        body['push_time'] + ' is not valid time.'\n      );\n    }\n    // Check pushTime is valid or not, if it is not valid, pushTime is NaN\n    if (!isFinite(date)) {\n      throw new Parse.Error(\n        Parse.Error.PUSH_MISCONFIGURED,\n        body['push_time'] + ' is not valid time.'\n      );\n    }\n\n    return {\n      date,\n      isLocalTime,\n    };\n  }\n\n  /**\n   * Checks if a ISO8601 formatted date contains a timezone component\n   * @param pushTimeParam {string}\n   * @returns {boolean}\n   */\n  static pushTimeHasTimezoneComponent(pushTimeParam: string): boolean {\n    const offsetPattern = /(.+)([+-])\\d\\d:\\d\\d$/;\n    return (\n      pushTimeParam.indexOf('Z') === pushTimeParam.length - 1 || offsetPattern.test(pushTimeParam) // 2007-04-05T12:30Z\n    ); // 2007-04-05T12:30.000+02:00, 2007-04-05T12:30.000-02:00\n  }\n\n  /**\n   * Converts a date to ISO format in UTC time and strips the timezone if `isLocalTime` is true\n   * @param date {Date}\n   * @param isLocalTime {boolean}\n   * @returns {string}\n   */\n  static formatPushTime({ date, isLocalTime }: { date: Date, isLocalTime: boolean }) {\n    if (isLocalTime) {\n      // Strip 'Z'\n      const isoString = date.toISOString();\n      return isoString.substring(0, isoString.indexOf('Z'));\n    }\n    return date.toISOString();\n  }\n}\n\nexport default PushController;\n"],"mappings":"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"}
225
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["PushController","sendPush","body","where","config","auth","onPushStatusSaved","now","Date","hasPushSupport","Parse","Error","PUSH_MISCONFIGURED","expiration_time","getExpirationTime","expiration_interval","getExpirationInterval","Object","prototype","hasOwnProperty","call","ttlMs","valueOf","pushTime","getPushTime","date","formatPushTime","badgeUpdate","Promise","resolve","data","badge","restUpdate","toLowerCase","__op","amount","Number","updateWhere","applyDeviceTokenExists","restQuery","RestQuery","method","Method","find","runBeforeFind","master","className","restWhere","buildRestWhere","then","write","RestWrite","runOptions","many","execute","pushStatus","pushStatusHandler","setInitial","objectId","audience_id","audienceId","updateAudience","lastUsed","__type","iso","toISOString","timesUsed","hasPushScheduledSupport","pushControllerQueue","enqueue","catch","err","fail","hasExpirationTime","expirationTimeParam","expirationTime","isFinite","hasExpirationInterval","expirationIntervalParam","hasPushTime","pushTimeParam","isLocalTime","pushTimeHasTimezoneComponent","offsetPattern","indexOf","length","test","isoString","substring"],"sources":["../../src/Controllers/PushController.js"],"sourcesContent":["import { Parse } from 'parse/node';\nimport RestQuery from '../RestQuery';\nimport RestWrite from '../RestWrite';\nimport { master } from '../Auth';\nimport { pushStatusHandler } from '../StatusHandler';\nimport { applyDeviceTokenExists } from '../Push/utils';\n\nexport class PushController {\n  sendPush(body = {}, where = {}, config, auth, onPushStatusSaved = () => {}, now = new Date()) {\n    if (!config.hasPushSupport) {\n      throw new Parse.Error(Parse.Error.PUSH_MISCONFIGURED, 'Missing push configuration');\n    }\n\n    // Replace the expiration_time and push_time with a valid Unix epoch milliseconds time\n    body.expiration_time = PushController.getExpirationTime(body);\n    body.expiration_interval = PushController.getExpirationInterval(body);\n    if (body.expiration_time && body.expiration_interval) {\n      throw new Parse.Error(\n        Parse.Error.PUSH_MISCONFIGURED,\n        'Both expiration_time and expiration_interval cannot be set'\n      );\n    }\n\n    // Immediate push\n    if (body.expiration_interval && !Object.prototype.hasOwnProperty.call(body, 'push_time')) {\n      const ttlMs = body.expiration_interval * 1000;\n      body.expiration_time = new Date(now.valueOf() + ttlMs).valueOf();\n    }\n\n    const pushTime = PushController.getPushTime(body);\n    if (pushTime && pushTime.date !== 'undefined') {\n      body['push_time'] = PushController.formatPushTime(pushTime);\n    }\n\n    // TODO: If the req can pass the checking, we return immediately instead of waiting\n    // pushes to be sent. We probably change this behaviour in the future.\n    let badgeUpdate = () => {\n      return Promise.resolve();\n    };\n\n    if (body.data && body.data.badge) {\n      const badge = body.data.badge;\n      let restUpdate = {};\n      if (typeof badge == 'string' && badge.toLowerCase() === 'increment') {\n        restUpdate = { badge: { __op: 'Increment', amount: 1 } };\n      } else if (\n        typeof badge == 'object' &&\n        typeof badge.__op == 'string' &&\n        badge.__op.toLowerCase() == 'increment' &&\n        Number(badge.amount)\n      ) {\n        restUpdate = { badge: { __op: 'Increment', amount: badge.amount } };\n      } else if (Number(badge)) {\n        restUpdate = { badge: badge };\n      } else {\n        throw \"Invalid value for badge, expected number or 'Increment' or {increment: number}\";\n      }\n\n      // Force filtering on only valid device tokens\n      const updateWhere = applyDeviceTokenExists(where);\n      badgeUpdate = async () => {\n        // Build a real RestQuery so we can use it in RestWrite\n        const restQuery = await RestQuery({\n          method: RestQuery.Method.find,\n          config,\n          runBeforeFind: false,\n          auth: master(config),\n          className: '_Installation',\n          restWhere: updateWhere,\n        });\n        return restQuery.buildRestWhere().then(() => {\n          const write = new RestWrite(\n            config,\n            master(config),\n            '_Installation',\n            restQuery.restWhere,\n            restUpdate\n          );\n          write.runOptions.many = true;\n          return write.execute();\n        });\n      };\n    }\n    const pushStatus = pushStatusHandler(config);\n    return Promise.resolve()\n      .then(() => {\n        return pushStatus.setInitial(body, where);\n      })\n      .then(() => {\n        onPushStatusSaved(pushStatus.objectId);\n        return badgeUpdate();\n      })\n      .then(() => {\n        // Update audience lastUsed and timesUsed\n        if (body.audience_id) {\n          const audienceId = body.audience_id;\n\n          var updateAudience = {\n            lastUsed: { __type: 'Date', iso: new Date().toISOString() },\n            timesUsed: { __op: 'Increment', amount: 1 },\n          };\n          const write = new RestWrite(\n            config,\n            master(config),\n            '_Audience',\n            { objectId: audienceId },\n            updateAudience\n          );\n          write.execute();\n        }\n        // Don't wait for the audience update promise to resolve.\n        return Promise.resolve();\n      })\n      .then(() => {\n        if (\n          Object.prototype.hasOwnProperty.call(body, 'push_time') &&\n          config.hasPushScheduledSupport\n        ) {\n          return Promise.resolve();\n        }\n        return config.pushControllerQueue.enqueue(body, where, config, auth, pushStatus);\n      })\n      .catch(err => {\n        return pushStatus.fail(err).then(() => {\n          throw err;\n        });\n      });\n  }\n\n  /**\n   * Get expiration time from the request body.\n   * @param {Object} request A request object\n   * @returns {Number|undefined} The expiration time if it exists in the request\n   */\n  static getExpirationTime(body = {}) {\n    var hasExpirationTime = Object.prototype.hasOwnProperty.call(body, 'expiration_time');\n    if (!hasExpirationTime) {\n      return;\n    }\n    var expirationTimeParam = body['expiration_time'];\n    var expirationTime;\n    if (typeof expirationTimeParam === 'number') {\n      expirationTime = new Date(expirationTimeParam * 1000);\n    } else if (typeof expirationTimeParam === 'string') {\n      expirationTime = new Date(expirationTimeParam);\n    } else {\n      throw new Parse.Error(\n        Parse.Error.PUSH_MISCONFIGURED,\n        body['expiration_time'] + ' is not valid time.'\n      );\n    }\n    // Check expirationTime is valid or not, if it is not valid, expirationTime is NaN\n    if (!isFinite(expirationTime)) {\n      throw new Parse.Error(\n        Parse.Error.PUSH_MISCONFIGURED,\n        body['expiration_time'] + ' is not valid time.'\n      );\n    }\n    return expirationTime.valueOf();\n  }\n\n  static getExpirationInterval(body = {}) {\n    const hasExpirationInterval = Object.prototype.hasOwnProperty.call(body, 'expiration_interval');\n    if (!hasExpirationInterval) {\n      return;\n    }\n\n    var expirationIntervalParam = body['expiration_interval'];\n    if (typeof expirationIntervalParam !== 'number' || expirationIntervalParam <= 0) {\n      throw new Parse.Error(\n        Parse.Error.PUSH_MISCONFIGURED,\n        `expiration_interval must be a number greater than 0`\n      );\n    }\n    return expirationIntervalParam;\n  }\n\n  /**\n   * Get push time from the request body.\n   * @param {Object} request A request object\n   * @returns {Number|undefined} The push time if it exists in the request\n   */\n  static getPushTime(body = {}) {\n    var hasPushTime = Object.prototype.hasOwnProperty.call(body, 'push_time');\n    if (!hasPushTime) {\n      return;\n    }\n    var pushTimeParam = body['push_time'];\n    var date;\n    var isLocalTime = true;\n\n    if (typeof pushTimeParam === 'number') {\n      date = new Date(pushTimeParam * 1000);\n    } else if (typeof pushTimeParam === 'string') {\n      isLocalTime = !PushController.pushTimeHasTimezoneComponent(pushTimeParam);\n      date = new Date(pushTimeParam);\n    } else {\n      throw new Parse.Error(\n        Parse.Error.PUSH_MISCONFIGURED,\n        body['push_time'] + ' is not valid time.'\n      );\n    }\n    // Check pushTime is valid or not, if it is not valid, pushTime is NaN\n    if (!isFinite(date)) {\n      throw new Parse.Error(\n        Parse.Error.PUSH_MISCONFIGURED,\n        body['push_time'] + ' is not valid time.'\n      );\n    }\n\n    return {\n      date,\n      isLocalTime,\n    };\n  }\n\n  /**\n   * Checks if a ISO8601 formatted date contains a timezone component\n   * @param pushTimeParam {string}\n   * @returns {boolean}\n   */\n  static pushTimeHasTimezoneComponent(pushTimeParam: string): boolean {\n    const offsetPattern = /(.+)([+-])\\d\\d:\\d\\d$/;\n    return (\n      pushTimeParam.indexOf('Z') === pushTimeParam.length - 1 || offsetPattern.test(pushTimeParam) // 2007-04-05T12:30Z\n    ); // 2007-04-05T12:30.000+02:00, 2007-04-05T12:30.000-02:00\n  }\n\n  /**\n   * Converts a date to ISO format in UTC time and strips the timezone if `isLocalTime` is true\n   * @param date {Date}\n   * @param isLocalTime {boolean}\n   * @returns {string}\n   */\n  static formatPushTime({ date, isLocalTime }: { date: Date, isLocalTime: boolean }) {\n    if (isLocalTime) {\n      // Strip 'Z'\n      const isoString = date.toISOString();\n      return isoString.substring(0, isoString.indexOf('Z'));\n    }\n    return date.toISOString();\n  }\n}\n\nexport default PushController;\n"],"mappings":"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"}
@@ -13,6 +13,11 @@ var _node = _interopRequireDefault(require("parse/node"));
13
13
  var _AccountLockout = _interopRequireDefault(require("../AccountLockout"));
14
14
  var _Config = _interopRequireDefault(require("../Config"));
15
15
  function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
16
+ function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }
17
+ function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { _defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }
18
+ function _defineProperty(obj, key, value) { key = _toPropertyKey(key); if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }
19
+ function _toPropertyKey(arg) { var key = _toPrimitive(arg, "string"); return typeof key === "symbol" ? key : String(key); }
20
+ function _toPrimitive(input, hint) { if (typeof input !== "object" || input === null) return input; var prim = input[Symbol.toPrimitive]; if (prim !== undefined) { var res = prim.call(input, hint || "default"); if (typeof res !== "object") return res; throw new TypeError("@@toPrimitive must return a primitive value."); } return (hint === "string" ? String : Number)(input); }
16
21
  var RestQuery = require('../RestQuery');
17
22
  var Auth = require('../Auth');
18
23
  class UserController extends _AdaptableController.default {
@@ -33,18 +38,28 @@ class UserController extends _AdaptableController.default {
33
38
  return _MailAdapter.default;
34
39
  }
35
40
  get shouldVerifyEmails() {
36
- return this.options.verifyUserEmails;
41
+ return (this.config || this.options).verifyUserEmails;
37
42
  }
38
- setEmailVerifyToken(user) {
39
- if (this.shouldVerifyEmails) {
40
- user._email_verify_token = (0, _cryptoUtils.randomString)(25);
43
+ async setEmailVerifyToken(user, req, storage = {}) {
44
+ let shouldSendEmail = this.shouldVerifyEmails;
45
+ if (typeof shouldSendEmail === 'function') {
46
+ const response = await Promise.resolve(shouldSendEmail(req));
47
+ shouldSendEmail = response !== false;
48
+ }
49
+ if (!shouldSendEmail) {
50
+ return false;
51
+ }
52
+ storage.sendVerificationEmail = true;
53
+ user._email_verify_token = (0, _cryptoUtils.randomString)(25);
54
+ if (!storage.fieldsChangedByTrigger || !storage.fieldsChangedByTrigger.includes('emailVerified')) {
41
55
  user.emailVerified = false;
42
- if (this.config.emailVerifyTokenValidityDuration) {
43
- user._email_verify_token_expires_at = _node.default._encode(this.config.generateEmailVerifyTokenExpiresAt());
44
- }
45
56
  }
57
+ if (this.config.emailVerifyTokenValidityDuration) {
58
+ user._email_verify_token_expires_at = _node.default._encode(this.config.generateEmailVerifyTokenExpiresAt());
59
+ }
60
+ return true;
46
61
  }
47
- verifyEmail(username, token) {
62
+ async verifyEmail(username, token) {
48
63
  if (!this.shouldVerifyEmails) {
49
64
  // Trying to verify email when not enabled
50
65
  // TODO: Better error here.
@@ -73,8 +88,14 @@ class UserController extends _AdaptableController.default {
73
88
  };
74
89
  }
75
90
  const maintenanceAuth = Auth.maintenance(this.config);
76
- var findUserForEmailVerification = new RestQuery(this.config, maintenanceAuth, '_User', {
77
- username
91
+ var findUserForEmailVerification = await RestQuery({
92
+ method: RestQuery.Method.get,
93
+ config: this.config,
94
+ auth: maintenanceAuth,
95
+ className: '_User',
96
+ restWhere: {
97
+ username
98
+ }
78
99
  });
79
100
  return findUserForEmailVerification.execute().then(result => {
80
101
  if (result.results.length && result.results[0].emailVerified) {
@@ -105,7 +126,7 @@ class UserController extends _AdaptableController.default {
105
126
  return results[0];
106
127
  });
107
128
  }
108
- getUserIfNeeded(user) {
129
+ async getUserIfNeeded(user) {
109
130
  if (user.username && user.email) {
110
131
  return Promise.resolve(user);
111
132
  }
@@ -116,7 +137,14 @@ class UserController extends _AdaptableController.default {
116
137
  if (user.email) {
117
138
  where.email = user.email;
118
139
  }
119
- var query = new RestQuery(this.config, Auth.master(this.config), '_User', where);
140
+ var query = await RestQuery({
141
+ method: RestQuery.Method.get,
142
+ config: this.config,
143
+ runBeforeFind: false,
144
+ auth: Auth.master(this.config),
145
+ className: '_User',
146
+ restWhere: where
147
+ });
120
148
  return query.execute().then(function (result) {
121
149
  if (result.results.length != 1) {
122
150
  throw undefined;
@@ -124,26 +152,39 @@ class UserController extends _AdaptableController.default {
124
152
  return result.results[0];
125
153
  });
126
154
  }
127
- sendVerificationEmail(user) {
155
+ async sendVerificationEmail(user, req) {
128
156
  if (!this.shouldVerifyEmails) {
129
157
  return;
130
158
  }
131
159
  const token = encodeURIComponent(user._email_verify_token);
132
160
  // We may need to fetch the user in case of update email
133
- this.getUserIfNeeded(user).then(user => {
134
- const username = encodeURIComponent(user.username);
135
- const link = buildEmailLink(this.config.verifyEmailURL, username, token, this.config);
136
- const options = {
137
- appName: this.config.appName,
138
- link: link,
139
- user: (0, _triggers.inflate)('_User', user)
140
- };
141
- if (this.adapter.sendVerificationEmail) {
142
- this.adapter.sendVerificationEmail(options);
143
- } else {
144
- this.adapter.sendMail(this.defaultVerificationEmail(options));
145
- }
146
- });
161
+ const fetchedUser = await this.getUserIfNeeded(user);
162
+ let shouldSendEmail = this.config.sendUserEmailVerification;
163
+ if (typeof shouldSendEmail === 'function') {
164
+ var _req$auth;
165
+ const response = await Promise.resolve(this.config.sendUserEmailVerification({
166
+ user: _node.default.Object.fromJSON(_objectSpread({
167
+ className: '_User'
168
+ }, fetchedUser)),
169
+ master: (_req$auth = req.auth) === null || _req$auth === void 0 ? void 0 : _req$auth.isMaster
170
+ }));
171
+ shouldSendEmail = !!response;
172
+ }
173
+ if (!shouldSendEmail) {
174
+ return;
175
+ }
176
+ const username = encodeURIComponent(user.username);
177
+ const link = buildEmailLink(this.config.verifyEmailURL, username, token, this.config);
178
+ const options = {
179
+ appName: this.config.appName,
180
+ link: link,
181
+ user: (0, _triggers.inflate)('_User', fetchedUser)
182
+ };
183
+ if (this.adapter.sendVerificationEmail) {
184
+ this.adapter.sendVerificationEmail(options);
185
+ } else {
186
+ this.adapter.sendMail(this.defaultVerificationEmail(options));
187
+ }
147
188
  }
148
189
 
149
190
  /**
@@ -152,7 +193,7 @@ class UserController extends _AdaptableController.default {
152
193
  * @param user
153
194
  * @returns {*}
154
195
  */
155
- regenerateEmailVerifyToken(user) {
196
+ async regenerateEmailVerifyToken(user, master) {
156
197
  const {
157
198
  _email_verify_token
158
199
  } = user;
@@ -165,22 +206,29 @@ class UserController extends _AdaptableController.default {
165
206
  if (this.config.emailVerifyTokenReuseIfValid && this.config.emailVerifyTokenValidityDuration && _email_verify_token && new Date() < new Date(_email_verify_token_expires_at)) {
166
207
  return Promise.resolve();
167
208
  }
168
- this.setEmailVerifyToken(user);
209
+ const shouldSend = await this.setEmailVerifyToken(user, {
210
+ user,
211
+ master
212
+ });
213
+ if (!shouldSend) {
214
+ return;
215
+ }
169
216
  return this.config.database.update('_User', {
170
217
  username: user.username
171
218
  }, user);
172
219
  }
173
- resendVerificationEmail(username) {
174
- return this.getUserIfNeeded({
220
+ async resendVerificationEmail(username, req) {
221
+ var _req$auth2;
222
+ const aUser = await this.getUserIfNeeded({
175
223
  username: username
176
- }).then(aUser => {
177
- if (!aUser || aUser.emailVerified) {
178
- throw undefined;
179
- }
180
- return this.regenerateEmailVerifyToken(aUser).then(() => {
181
- this.sendVerificationEmail(aUser);
182
- });
183
224
  });
225
+ if (!aUser || aUser.emailVerified) {
226
+ throw undefined;
227
+ }
228
+ const generate = await this.regenerateEmailVerifyToken(aUser, (_req$auth2 = req.auth) === null || _req$auth2 === void 0 ? void 0 : _req$auth2.isMaster);
229
+ if (generate) {
230
+ this.sendVerificationEmail(aUser, req);
231
+ }
184
232
  }
185
233
  setPasswordResetToken(email) {
186
234
  const token = {
@@ -317,4 +365,4 @@ function buildEmailLink(destination, username, token, config) {
317
365
  }
318
366
  var _default = UserController;
319
367
  exports.default = _default;
320
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["RestQuery","require","Auth","UserController","AdaptableController","constructor","adapter","appId","options","config","Config","get","validateAdapter","shouldVerifyEmails","expectedAdapterType","MailAdapter","verifyUserEmails","setEmailVerifyToken","user","_email_verify_token","randomString","emailVerified","emailVerifyTokenValidityDuration","_email_verify_token_expires_at","Parse","_encode","generateEmailVerifyTokenExpiresAt","verifyEmail","username","token","undefined","query","updateFields","__op","$gt","Date","maintenanceAuth","maintenance","findUserForEmailVerification","execute","then","result","results","length","Promise","resolve","objectId","rest","update","checkResetTokenValidity","database","find","_perishable_token","limit","passwordPolicy","resetTokenValidityDuration","expiresDate","_perishable_token_expires_at","__type","iso","getUserIfNeeded","email","where","master","sendVerificationEmail","encodeURIComponent","link","buildEmailLink","verifyEmailURL","appName","inflate","sendMail","defaultVerificationEmail","regenerateEmailVerifyToken","emailVerifyTokenReuseIfValid","resendVerificationEmail","aUser","setPasswordResetToken","generatePasswordResetTokenExpiresAt","$or","$exists","sendPasswordResetEmail","resetTokenReuseIfValid","requestResetPasswordURL","defaultResetPasswordEmail","updatePassword","password","updateUserPassword","accountLockoutPolicy","AccountLockout","unlockAccount","catch","error","message","reject","text","to","subject","destination","usernameAndToken","parseFrameURL","destinationWithoutHost","replace","publicServerURL"],"sources":["../../src/Controllers/UserController.js"],"sourcesContent":["import { randomString } from '../cryptoUtils';\nimport { inflate } from '../triggers';\nimport AdaptableController from './AdaptableController';\nimport MailAdapter from '../Adapters/Email/MailAdapter';\nimport rest from '../rest';\nimport Parse from 'parse/node';\nimport AccountLockout from '../AccountLockout';\nimport Config from '../Config';\n\nvar RestQuery = require('../RestQuery');\nvar Auth = require('../Auth');\n\nexport class UserController extends AdaptableController {\n  constructor(adapter, appId, options = {}) {\n    super(adapter, appId, options);\n  }\n\n  get config() {\n    return Config.get(this.appId);\n  }\n\n  validateAdapter(adapter) {\n    // Allow no adapter\n    if (!adapter && !this.shouldVerifyEmails) {\n      return;\n    }\n    super.validateAdapter(adapter);\n  }\n\n  expectedAdapterType() {\n    return MailAdapter;\n  }\n\n  get shouldVerifyEmails() {\n    return this.options.verifyUserEmails;\n  }\n\n  setEmailVerifyToken(user) {\n    if (this.shouldVerifyEmails) {\n      user._email_verify_token = randomString(25);\n      user.emailVerified = false;\n\n      if (this.config.emailVerifyTokenValidityDuration) {\n        user._email_verify_token_expires_at = Parse._encode(\n          this.config.generateEmailVerifyTokenExpiresAt()\n        );\n      }\n    }\n  }\n\n  verifyEmail(username, token) {\n    if (!this.shouldVerifyEmails) {\n      // Trying to verify email when not enabled\n      // TODO: Better error here.\n      throw undefined;\n    }\n\n    const query = { username: username, _email_verify_token: token };\n    const updateFields = {\n      emailVerified: true,\n      _email_verify_token: { __op: 'Delete' },\n    };\n\n    // if the email verify token needs to be validated then\n    // add additional query params and additional fields that need to be updated\n    if (this.config.emailVerifyTokenValidityDuration) {\n      query.emailVerified = false;\n      query._email_verify_token_expires_at = { $gt: Parse._encode(new Date()) };\n\n      updateFields._email_verify_token_expires_at = { __op: 'Delete' };\n    }\n    const maintenanceAuth = Auth.maintenance(this.config);\n    var findUserForEmailVerification = new RestQuery(this.config, maintenanceAuth, '_User', {\n      username,\n    });\n    return findUserForEmailVerification.execute().then(result => {\n      if (result.results.length && result.results[0].emailVerified) {\n        return Promise.resolve(result.results.length[0]);\n      } else if (result.results.length) {\n        query.objectId = result.results[0].objectId;\n      }\n      return rest.update(this.config, maintenanceAuth, '_User', query, updateFields);\n    });\n  }\n\n  checkResetTokenValidity(username, token) {\n    return this.config.database\n      .find(\n        '_User',\n        {\n          username: username,\n          _perishable_token: token,\n        },\n        { limit: 1 },\n        Auth.maintenance(this.config)\n      )\n      .then(results => {\n        if (results.length != 1) {\n          throw 'Failed to reset password: username / email / token is invalid';\n        }\n\n        if (this.config.passwordPolicy && this.config.passwordPolicy.resetTokenValidityDuration) {\n          let expiresDate = results[0]._perishable_token_expires_at;\n          if (expiresDate && expiresDate.__type == 'Date') {\n            expiresDate = new Date(expiresDate.iso);\n          }\n          if (expiresDate < new Date()) throw 'The password reset link has expired';\n        }\n        return results[0];\n      });\n  }\n\n  getUserIfNeeded(user) {\n    if (user.username && user.email) {\n      return Promise.resolve(user);\n    }\n    var where = {};\n    if (user.username) {\n      where.username = user.username;\n    }\n    if (user.email) {\n      where.email = user.email;\n    }\n\n    var query = new RestQuery(this.config, Auth.master(this.config), '_User', where);\n    return query.execute().then(function (result) {\n      if (result.results.length != 1) {\n        throw undefined;\n      }\n      return result.results[0];\n    });\n  }\n\n  sendVerificationEmail(user) {\n    if (!this.shouldVerifyEmails) {\n      return;\n    }\n    const token = encodeURIComponent(user._email_verify_token);\n    // We may need to fetch the user in case of update email\n    this.getUserIfNeeded(user).then(user => {\n      const username = encodeURIComponent(user.username);\n\n      const link = buildEmailLink(this.config.verifyEmailURL, username, token, this.config);\n      const options = {\n        appName: this.config.appName,\n        link: link,\n        user: inflate('_User', user),\n      };\n      if (this.adapter.sendVerificationEmail) {\n        this.adapter.sendVerificationEmail(options);\n      } else {\n        this.adapter.sendMail(this.defaultVerificationEmail(options));\n      }\n    });\n  }\n\n  /**\n   * Regenerates the given user's email verification token\n   *\n   * @param user\n   * @returns {*}\n   */\n  regenerateEmailVerifyToken(user) {\n    const { _email_verify_token } = user;\n    let { _email_verify_token_expires_at } = user;\n    if (_email_verify_token_expires_at && _email_verify_token_expires_at.__type === 'Date') {\n      _email_verify_token_expires_at = _email_verify_token_expires_at.iso;\n    }\n    if (\n      this.config.emailVerifyTokenReuseIfValid &&\n      this.config.emailVerifyTokenValidityDuration &&\n      _email_verify_token &&\n      new Date() < new Date(_email_verify_token_expires_at)\n    ) {\n      return Promise.resolve();\n    }\n    this.setEmailVerifyToken(user);\n    return this.config.database.update('_User', { username: user.username }, user);\n  }\n\n  resendVerificationEmail(username) {\n    return this.getUserIfNeeded({ username: username }).then(aUser => {\n      if (!aUser || aUser.emailVerified) {\n        throw undefined;\n      }\n      return this.regenerateEmailVerifyToken(aUser).then(() => {\n        this.sendVerificationEmail(aUser);\n      });\n    });\n  }\n\n  setPasswordResetToken(email) {\n    const token = { _perishable_token: randomString(25) };\n\n    if (this.config.passwordPolicy && this.config.passwordPolicy.resetTokenValidityDuration) {\n      token._perishable_token_expires_at = Parse._encode(\n        this.config.generatePasswordResetTokenExpiresAt()\n      );\n    }\n\n    return this.config.database.update(\n      '_User',\n      { $or: [{ email }, { username: email, email: { $exists: false } }] },\n      token,\n      {},\n      true\n    );\n  }\n\n  async sendPasswordResetEmail(email) {\n    if (!this.adapter) {\n      throw 'Trying to send a reset password but no adapter is set';\n      //  TODO: No adapter?\n    }\n    let user;\n    if (\n      this.config.passwordPolicy &&\n      this.config.passwordPolicy.resetTokenReuseIfValid &&\n      this.config.passwordPolicy.resetTokenValidityDuration\n    ) {\n      const results = await this.config.database.find(\n        '_User',\n        {\n          $or: [\n            { email, _perishable_token: { $exists: true } },\n            { username: email, email: { $exists: false }, _perishable_token: { $exists: true } },\n          ],\n        },\n        { limit: 1 },\n        Auth.maintenance(this.config)\n      );\n      if (results.length == 1) {\n        let expiresDate = results[0]._perishable_token_expires_at;\n        if (expiresDate && expiresDate.__type == 'Date') {\n          expiresDate = new Date(expiresDate.iso);\n        }\n        if (expiresDate > new Date()) {\n          user = results[0];\n        }\n      }\n    }\n    if (!user || !user._perishable_token) {\n      user = await this.setPasswordResetToken(email);\n    }\n    const token = encodeURIComponent(user._perishable_token);\n    const username = encodeURIComponent(user.username);\n\n    const link = buildEmailLink(this.config.requestResetPasswordURL, username, token, this.config);\n    const options = {\n      appName: this.config.appName,\n      link: link,\n      user: inflate('_User', user),\n    };\n\n    if (this.adapter.sendPasswordResetEmail) {\n      this.adapter.sendPasswordResetEmail(options);\n    } else {\n      this.adapter.sendMail(this.defaultResetPasswordEmail(options));\n    }\n\n    return Promise.resolve(user);\n  }\n\n  updatePassword(username, token, password) {\n    return this.checkResetTokenValidity(username, token)\n      .then(user => updateUserPassword(user, password, this.config))\n      .then(user => {\n        const accountLockoutPolicy = new AccountLockout(user, this.config);\n        return accountLockoutPolicy.unlockAccount();\n      })\n      .catch(error => {\n        if (error && error.message) {\n          // in case of Parse.Error, fail with the error message only\n          return Promise.reject(error.message);\n        } else {\n          return Promise.reject(error);\n        }\n      });\n  }\n\n  defaultVerificationEmail({ link, user, appName }) {\n    const text =\n      'Hi,\\n\\n' +\n      'You are being asked to confirm the e-mail address ' +\n      user.get('email') +\n      ' with ' +\n      appName +\n      '\\n\\n' +\n      '' +\n      'Click here to confirm it:\\n' +\n      link;\n    const to = user.get('email');\n    const subject = 'Please verify your e-mail for ' + appName;\n    return { text, to, subject };\n  }\n\n  defaultResetPasswordEmail({ link, user, appName }) {\n    const text =\n      'Hi,\\n\\n' +\n      'You requested to reset your password for ' +\n      appName +\n      (user.get('username') ? \" (your username is '\" + user.get('username') + \"')\" : '') +\n      '.\\n\\n' +\n      '' +\n      'Click here to reset it:\\n' +\n      link;\n    const to = user.get('email') || user.get('username');\n    const subject = 'Password Reset for ' + appName;\n    return { text, to, subject };\n  }\n}\n\n// Mark this private\nfunction updateUserPassword(user, password, config) {\n  return rest\n    .update(\n      config,\n      Auth.master(config),\n      '_User',\n      { objectId: user.objectId },\n      {\n        password: password,\n      }\n    )\n    .then(() => user);\n}\n\nfunction buildEmailLink(destination, username, token, config) {\n  const usernameAndToken = `token=${token}&username=${username}`;\n\n  if (config.parseFrameURL) {\n    const destinationWithoutHost = destination.replace(config.publicServerURL, '');\n\n    return `${config.parseFrameURL}?link=${encodeURIComponent(\n      destinationWithoutHost\n    )}&${usernameAndToken}`;\n  } else {\n    return `${destination}?${usernameAndToken}`;\n  }\n}\n\nexport default UserController;\n"],"mappings":"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"}
368
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["RestQuery","require","Auth","UserController","AdaptableController","constructor","adapter","appId","options","config","Config","get","validateAdapter","shouldVerifyEmails","expectedAdapterType","MailAdapter","verifyUserEmails","setEmailVerifyToken","user","req","storage","shouldSendEmail","response","Promise","resolve","sendVerificationEmail","_email_verify_token","randomString","fieldsChangedByTrigger","includes","emailVerified","emailVerifyTokenValidityDuration","_email_verify_token_expires_at","Parse","_encode","generateEmailVerifyTokenExpiresAt","verifyEmail","username","token","undefined","query","updateFields","__op","$gt","Date","maintenanceAuth","maintenance","findUserForEmailVerification","method","Method","auth","className","restWhere","execute","then","result","results","length","objectId","rest","update","checkResetTokenValidity","database","find","_perishable_token","limit","passwordPolicy","resetTokenValidityDuration","expiresDate","_perishable_token_expires_at","__type","iso","getUserIfNeeded","email","where","runBeforeFind","master","encodeURIComponent","fetchedUser","sendUserEmailVerification","Object","fromJSON","isMaster","link","buildEmailLink","verifyEmailURL","appName","inflate","sendMail","defaultVerificationEmail","regenerateEmailVerifyToken","emailVerifyTokenReuseIfValid","shouldSend","resendVerificationEmail","aUser","generate","setPasswordResetToken","generatePasswordResetTokenExpiresAt","$or","$exists","sendPasswordResetEmail","resetTokenReuseIfValid","requestResetPasswordURL","defaultResetPasswordEmail","updatePassword","password","updateUserPassword","accountLockoutPolicy","AccountLockout","unlockAccount","catch","error","message","reject","text","to","subject","destination","usernameAndToken","parseFrameURL","destinationWithoutHost","replace","publicServerURL"],"sources":["../../src/Controllers/UserController.js"],"sourcesContent":["import { randomString } from '../cryptoUtils';\nimport { inflate } from '../triggers';\nimport AdaptableController from './AdaptableController';\nimport MailAdapter from '../Adapters/Email/MailAdapter';\nimport rest from '../rest';\nimport Parse from 'parse/node';\nimport AccountLockout from '../AccountLockout';\nimport Config from '../Config';\n\nvar RestQuery = require('../RestQuery');\nvar Auth = require('../Auth');\n\nexport class UserController extends AdaptableController {\n  constructor(adapter, appId, options = {}) {\n    super(adapter, appId, options);\n  }\n\n  get config() {\n    return Config.get(this.appId);\n  }\n\n  validateAdapter(adapter) {\n    // Allow no adapter\n    if (!adapter && !this.shouldVerifyEmails) {\n      return;\n    }\n    super.validateAdapter(adapter);\n  }\n\n  expectedAdapterType() {\n    return MailAdapter;\n  }\n\n  get shouldVerifyEmails() {\n    return (this.config || this.options).verifyUserEmails;\n  }\n\n  async setEmailVerifyToken(user, req, storage = {}) {\n    let shouldSendEmail = this.shouldVerifyEmails;\n    if (typeof shouldSendEmail === 'function') {\n      const response = await Promise.resolve(shouldSendEmail(req));\n      shouldSendEmail = response !== false;\n    }\n    if (!shouldSendEmail) {\n      return false;\n    }\n    storage.sendVerificationEmail = true;\n    user._email_verify_token = randomString(25);\n    if (\n      !storage.fieldsChangedByTrigger ||\n      !storage.fieldsChangedByTrigger.includes('emailVerified')\n    ) {\n      user.emailVerified = false;\n    }\n\n    if (this.config.emailVerifyTokenValidityDuration) {\n      user._email_verify_token_expires_at = Parse._encode(\n        this.config.generateEmailVerifyTokenExpiresAt()\n      );\n    }\n    return true;\n  }\n\n  async verifyEmail(username, token) {\n    if (!this.shouldVerifyEmails) {\n      // Trying to verify email when not enabled\n      // TODO: Better error here.\n      throw undefined;\n    }\n\n    const query = { username: username, _email_verify_token: token };\n    const updateFields = {\n      emailVerified: true,\n      _email_verify_token: { __op: 'Delete' },\n    };\n\n    // if the email verify token needs to be validated then\n    // add additional query params and additional fields that need to be updated\n    if (this.config.emailVerifyTokenValidityDuration) {\n      query.emailVerified = false;\n      query._email_verify_token_expires_at = { $gt: Parse._encode(new Date()) };\n\n      updateFields._email_verify_token_expires_at = { __op: 'Delete' };\n    }\n    const maintenanceAuth = Auth.maintenance(this.config);\n    var findUserForEmailVerification = await RestQuery({\n      method: RestQuery.Method.get,\n      config: this.config,\n      auth: maintenanceAuth,\n      className: '_User',\n      restWhere: {\n        username,\n      },\n    });\n    return findUserForEmailVerification.execute().then(result => {\n      if (result.results.length && result.results[0].emailVerified) {\n        return Promise.resolve(result.results.length[0]);\n      } else if (result.results.length) {\n        query.objectId = result.results[0].objectId;\n      }\n      return rest.update(this.config, maintenanceAuth, '_User', query, updateFields);\n    });\n  }\n\n  checkResetTokenValidity(username, token) {\n    return this.config.database\n      .find(\n        '_User',\n        {\n          username: username,\n          _perishable_token: token,\n        },\n        { limit: 1 },\n        Auth.maintenance(this.config)\n      )\n      .then(results => {\n        if (results.length != 1) {\n          throw 'Failed to reset password: username / email / token is invalid';\n        }\n\n        if (this.config.passwordPolicy && this.config.passwordPolicy.resetTokenValidityDuration) {\n          let expiresDate = results[0]._perishable_token_expires_at;\n          if (expiresDate && expiresDate.__type == 'Date') {\n            expiresDate = new Date(expiresDate.iso);\n          }\n          if (expiresDate < new Date()) throw 'The password reset link has expired';\n        }\n        return results[0];\n      });\n  }\n\n  async getUserIfNeeded(user) {\n    if (user.username && user.email) {\n      return Promise.resolve(user);\n    }\n    var where = {};\n    if (user.username) {\n      where.username = user.username;\n    }\n    if (user.email) {\n      where.email = user.email;\n    }\n\n    var query = await RestQuery({\n      method: RestQuery.Method.get,\n      config: this.config,\n      runBeforeFind: false,\n      auth: Auth.master(this.config),\n      className: '_User',\n      restWhere: where,\n    });\n    return query.execute().then(function (result) {\n      if (result.results.length != 1) {\n        throw undefined;\n      }\n      return result.results[0];\n    });\n  }\n\n  async sendVerificationEmail(user, req) {\n    if (!this.shouldVerifyEmails) {\n      return;\n    }\n    const token = encodeURIComponent(user._email_verify_token);\n    // We may need to fetch the user in case of update email\n    const fetchedUser = await this.getUserIfNeeded(user);\n    let shouldSendEmail = this.config.sendUserEmailVerification;\n    if (typeof shouldSendEmail === 'function') {\n      const response = await Promise.resolve(\n        this.config.sendUserEmailVerification({\n          user: Parse.Object.fromJSON({ className: '_User', ...fetchedUser }),\n          master: req.auth?.isMaster,\n        })\n      );\n      shouldSendEmail = !!response;\n    }\n    if (!shouldSendEmail) {\n      return;\n    }\n    const username = encodeURIComponent(user.username);\n\n    const link = buildEmailLink(this.config.verifyEmailURL, username, token, this.config);\n    const options = {\n      appName: this.config.appName,\n      link: link,\n      user: inflate('_User', fetchedUser),\n    };\n    if (this.adapter.sendVerificationEmail) {\n      this.adapter.sendVerificationEmail(options);\n    } else {\n      this.adapter.sendMail(this.defaultVerificationEmail(options));\n    }\n  }\n\n  /**\n   * Regenerates the given user's email verification token\n   *\n   * @param user\n   * @returns {*}\n   */\n  async regenerateEmailVerifyToken(user, master) {\n    const { _email_verify_token } = user;\n    let { _email_verify_token_expires_at } = user;\n    if (_email_verify_token_expires_at && _email_verify_token_expires_at.__type === 'Date') {\n      _email_verify_token_expires_at = _email_verify_token_expires_at.iso;\n    }\n    if (\n      this.config.emailVerifyTokenReuseIfValid &&\n      this.config.emailVerifyTokenValidityDuration &&\n      _email_verify_token &&\n      new Date() < new Date(_email_verify_token_expires_at)\n    ) {\n      return Promise.resolve();\n    }\n    const shouldSend = await this.setEmailVerifyToken(user, { user, master });\n    if (!shouldSend) {\n      return;\n    }\n    return this.config.database.update('_User', { username: user.username }, user);\n  }\n\n  async resendVerificationEmail(username, req) {\n    const aUser = await this.getUserIfNeeded({ username: username });\n    if (!aUser || aUser.emailVerified) {\n      throw undefined;\n    }\n    const generate = await this.regenerateEmailVerifyToken(aUser, req.auth?.isMaster);\n    if (generate) {\n      this.sendVerificationEmail(aUser, req);\n    }\n  }\n\n  setPasswordResetToken(email) {\n    const token = { _perishable_token: randomString(25) };\n\n    if (this.config.passwordPolicy && this.config.passwordPolicy.resetTokenValidityDuration) {\n      token._perishable_token_expires_at = Parse._encode(\n        this.config.generatePasswordResetTokenExpiresAt()\n      );\n    }\n\n    return this.config.database.update(\n      '_User',\n      { $or: [{ email }, { username: email, email: { $exists: false } }] },\n      token,\n      {},\n      true\n    );\n  }\n\n  async sendPasswordResetEmail(email) {\n    if (!this.adapter) {\n      throw 'Trying to send a reset password but no adapter is set';\n      //  TODO: No adapter?\n    }\n    let user;\n    if (\n      this.config.passwordPolicy &&\n      this.config.passwordPolicy.resetTokenReuseIfValid &&\n      this.config.passwordPolicy.resetTokenValidityDuration\n    ) {\n      const results = await this.config.database.find(\n        '_User',\n        {\n          $or: [\n            { email, _perishable_token: { $exists: true } },\n            { username: email, email: { $exists: false }, _perishable_token: { $exists: true } },\n          ],\n        },\n        { limit: 1 },\n        Auth.maintenance(this.config)\n      );\n      if (results.length == 1) {\n        let expiresDate = results[0]._perishable_token_expires_at;\n        if (expiresDate && expiresDate.__type == 'Date') {\n          expiresDate = new Date(expiresDate.iso);\n        }\n        if (expiresDate > new Date()) {\n          user = results[0];\n        }\n      }\n    }\n    if (!user || !user._perishable_token) {\n      user = await this.setPasswordResetToken(email);\n    }\n    const token = encodeURIComponent(user._perishable_token);\n    const username = encodeURIComponent(user.username);\n\n    const link = buildEmailLink(this.config.requestResetPasswordURL, username, token, this.config);\n    const options = {\n      appName: this.config.appName,\n      link: link,\n      user: inflate('_User', user),\n    };\n\n    if (this.adapter.sendPasswordResetEmail) {\n      this.adapter.sendPasswordResetEmail(options);\n    } else {\n      this.adapter.sendMail(this.defaultResetPasswordEmail(options));\n    }\n\n    return Promise.resolve(user);\n  }\n\n  updatePassword(username, token, password) {\n    return this.checkResetTokenValidity(username, token)\n      .then(user => updateUserPassword(user, password, this.config))\n      .then(user => {\n        const accountLockoutPolicy = new AccountLockout(user, this.config);\n        return accountLockoutPolicy.unlockAccount();\n      })\n      .catch(error => {\n        if (error && error.message) {\n          // in case of Parse.Error, fail with the error message only\n          return Promise.reject(error.message);\n        } else {\n          return Promise.reject(error);\n        }\n      });\n  }\n\n  defaultVerificationEmail({ link, user, appName }) {\n    const text =\n      'Hi,\\n\\n' +\n      'You are being asked to confirm the e-mail address ' +\n      user.get('email') +\n      ' with ' +\n      appName +\n      '\\n\\n' +\n      '' +\n      'Click here to confirm it:\\n' +\n      link;\n    const to = user.get('email');\n    const subject = 'Please verify your e-mail for ' + appName;\n    return { text, to, subject };\n  }\n\n  defaultResetPasswordEmail({ link, user, appName }) {\n    const text =\n      'Hi,\\n\\n' +\n      'You requested to reset your password for ' +\n      appName +\n      (user.get('username') ? \" (your username is '\" + user.get('username') + \"')\" : '') +\n      '.\\n\\n' +\n      '' +\n      'Click here to reset it:\\n' +\n      link;\n    const to = user.get('email') || user.get('username');\n    const subject = 'Password Reset for ' + appName;\n    return { text, to, subject };\n  }\n}\n\n// Mark this private\nfunction updateUserPassword(user, password, config) {\n  return rest\n    .update(\n      config,\n      Auth.master(config),\n      '_User',\n      { objectId: user.objectId },\n      {\n        password: password,\n      }\n    )\n    .then(() => user);\n}\n\nfunction buildEmailLink(destination, username, token, config) {\n  const usernameAndToken = `token=${token}&username=${username}`;\n\n  if (config.parseFrameURL) {\n    const destinationWithoutHost = destination.replace(config.publicServerURL, '');\n\n    return `${config.parseFrameURL}?link=${encodeURIComponent(\n      destinationWithoutHost\n    )}&${usernameAndToken}`;\n  } else {\n    return `${destination}?${usernameAndToken}`;\n  }\n}\n\nexport default UserController;\n"],"mappings":"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"}
@@ -23,5 +23,8 @@ module.exports = [{
23
23
  }, {
24
24
  optionKey: 'allowExpiredAuthDataToken',
25
25
  changeNewDefault: 'false'
26
+ }, {
27
+ optionKey: 'encodeParseObjectInCloudFunction',
28
+ changeNewDefault: 'true'
26
29
  }];
27
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJtb2R1bGUiLCJleHBvcnRzIiwib3B0aW9uS2V5IiwiY2hhbmdlTmV3RGVmYXVsdCJdLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9EZXByZWNhdG9yL0RlcHJlY2F0aW9ucy5qcyJdLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIFRoZSBkZXByZWNhdGlvbnMuXG4gKlxuICogQWRkIGRlcHJlY2F0aW9ucyB0byB0aGUgYXJyYXkgdXNpbmcgdGhlIGZvbGxvd2luZyBrZXlzOlxuICogLSBgb3B0aW9uS2V5YCB7U3RyaW5nfTogVGhlIG9wdGlvbiBrZXkgaW5jbC4gaXRzIHBhdGgsIGUuZy4gYHNlY3VyaXR5LmVuYWJsZUNoZWNrYC5cbiAqIC0gYGVudktleWAge1N0cmluZ306IFRoZSBlbnZpcm9ubWVudCBrZXksIGUuZy4gYFBBUlNFX1NFUlZFUl9TRUNVUklUWWAuXG4gKiAtIGBjaGFuZ2VOZXdLZXlgIHtTdHJpbmd9OiBTZXQgdGhlIG5ldyBrZXkgbmFtZSBpZiB0aGUgY3VycmVudCBrZXkgd2lsbCBiZSByZXBsYWNlZCxcbiAqIG9yIHNldCB0byBhbiBlbXB0eSBzdHJpbmcgaWYgdGhlIGN1cnJlbnQga2V5IHdpbGwgYmUgcmVtb3ZlZCB3aXRob3V0IHJlcGxhY2VtZW50LlxuICogLSBgY2hhbmdlTmV3RGVmYXVsdGAge1N0cmluZ306IFNldCB0aGUgbmV3IGRlZmF1bHQgdmFsdWUgaWYgdGhlIGtleSdzIGRlZmF1bHQgdmFsdWVcbiAqIHdpbGwgY2hhbmdlIGluIGEgZnV0dXJlIHZlcnNpb24uXG4gKiAtIGBzb2x1dGlvbmA6IFRoZSBpbnN0cnVjdGlvbiB0byByZXNvbHZlIHRoaXMgZGVwcmVjYXRpb24gd2FybmluZy4gT3B0aW9uYWwuIFRoaXNcbiAqIGluc3RydWN0aW9uIG11c3Qgbm90IGluY2x1ZGUgdGhlIGRlcHJlY2F0aW9uIHdhcm5pbmcgd2hpY2ggaXMgYXV0by1nZW5lcmF0ZWQuXG4gKiBJdCBzaG91bGQgb25seSBjb250YWluIGFkZGl0aW9uYWwgaW5zdHJ1Y3Rpb24gcmVnYXJkaW5nIHRoZSBkZXByZWNhdGlvbiBpZlxuICogbmVjZXNzYXJ5LlxuICpcbiAqIElmIHRoZXJlIGFyZSBubyBkZXByZWNhdGlvbnMsIHRoaXMgbXVzdCByZXR1cm4gYW4gZW1wdHkgYXJyYXkuXG4gKi9cbm1vZHVsZS5leHBvcnRzID0gW1xuICB7IG9wdGlvbktleTogJ2FsbG93Q2xpZW50Q2xhc3NDcmVhdGlvbicsIGNoYW5nZU5ld0RlZmF1bHQ6ICdmYWxzZScgfSxcbiAgeyBvcHRpb25LZXk6ICdhbGxvd0V4cGlyZWRBdXRoRGF0YVRva2VuJywgY2hhbmdlTmV3RGVmYXVsdDogJ2ZhbHNlJyB9LFxuXTtcbiJdLCJtYXBwaW5ncyI6Ijs7QUFBQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0FBLE1BQU0sQ0FBQ0MsT0FBTyxHQUFHLENBQ2Y7RUFBRUMsU0FBUyxFQUFFLDBCQUEwQjtFQUFFQyxnQkFBZ0IsRUFBRTtBQUFRLENBQUMsRUFDcEU7RUFBRUQsU0FBUyxFQUFFLDJCQUEyQjtFQUFFQyxnQkFBZ0IsRUFBRTtBQUFRLENBQUMsQ0FDdEUifQ==
30
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJtb2R1bGUiLCJleHBvcnRzIiwib3B0aW9uS2V5IiwiY2hhbmdlTmV3RGVmYXVsdCJdLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9EZXByZWNhdG9yL0RlcHJlY2F0aW9ucy5qcyJdLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIFRoZSBkZXByZWNhdGlvbnMuXG4gKlxuICogQWRkIGRlcHJlY2F0aW9ucyB0byB0aGUgYXJyYXkgdXNpbmcgdGhlIGZvbGxvd2luZyBrZXlzOlxuICogLSBgb3B0aW9uS2V5YCB7U3RyaW5nfTogVGhlIG9wdGlvbiBrZXkgaW5jbC4gaXRzIHBhdGgsIGUuZy4gYHNlY3VyaXR5LmVuYWJsZUNoZWNrYC5cbiAqIC0gYGVudktleWAge1N0cmluZ306IFRoZSBlbnZpcm9ubWVudCBrZXksIGUuZy4gYFBBUlNFX1NFUlZFUl9TRUNVUklUWWAuXG4gKiAtIGBjaGFuZ2VOZXdLZXlgIHtTdHJpbmd9OiBTZXQgdGhlIG5ldyBrZXkgbmFtZSBpZiB0aGUgY3VycmVudCBrZXkgd2lsbCBiZSByZXBsYWNlZCxcbiAqIG9yIHNldCB0byBhbiBlbXB0eSBzdHJpbmcgaWYgdGhlIGN1cnJlbnQga2V5IHdpbGwgYmUgcmVtb3ZlZCB3aXRob3V0IHJlcGxhY2VtZW50LlxuICogLSBgY2hhbmdlTmV3RGVmYXVsdGAge1N0cmluZ306IFNldCB0aGUgbmV3IGRlZmF1bHQgdmFsdWUgaWYgdGhlIGtleSdzIGRlZmF1bHQgdmFsdWVcbiAqIHdpbGwgY2hhbmdlIGluIGEgZnV0dXJlIHZlcnNpb24uXG4gKiAtIGBzb2x1dGlvbmA6IFRoZSBpbnN0cnVjdGlvbiB0byByZXNvbHZlIHRoaXMgZGVwcmVjYXRpb24gd2FybmluZy4gT3B0aW9uYWwuIFRoaXNcbiAqIGluc3RydWN0aW9uIG11c3Qgbm90IGluY2x1ZGUgdGhlIGRlcHJlY2F0aW9uIHdhcm5pbmcgd2hpY2ggaXMgYXV0by1nZW5lcmF0ZWQuXG4gKiBJdCBzaG91bGQgb25seSBjb250YWluIGFkZGl0aW9uYWwgaW5zdHJ1Y3Rpb24gcmVnYXJkaW5nIHRoZSBkZXByZWNhdGlvbiBpZlxuICogbmVjZXNzYXJ5LlxuICpcbiAqIElmIHRoZXJlIGFyZSBubyBkZXByZWNhdGlvbnMsIHRoaXMgbXVzdCByZXR1cm4gYW4gZW1wdHkgYXJyYXkuXG4gKi9cbm1vZHVsZS5leHBvcnRzID0gW1xuICB7IG9wdGlvbktleTogJ2FsbG93Q2xpZW50Q2xhc3NDcmVhdGlvbicsIGNoYW5nZU5ld0RlZmF1bHQ6ICdmYWxzZScgfSxcbiAgeyBvcHRpb25LZXk6ICdhbGxvd0V4cGlyZWRBdXRoRGF0YVRva2VuJywgY2hhbmdlTmV3RGVmYXVsdDogJ2ZhbHNlJyB9LFxuICB7IG9wdGlvbktleTogJ2VuY29kZVBhcnNlT2JqZWN0SW5DbG91ZEZ1bmN0aW9uJywgY2hhbmdlTmV3RGVmYXVsdDogJ3RydWUnIH0sXG5dO1xuIl0sIm1hcHBpbmdzIjoiOztBQUFBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQUEsTUFBTSxDQUFDQyxPQUFPLEdBQUcsQ0FDZjtFQUFFQyxTQUFTLEVBQUUsMEJBQTBCO0VBQUVDLGdCQUFnQixFQUFFO0FBQVEsQ0FBQyxFQUNwRTtFQUFFRCxTQUFTLEVBQUUsMkJBQTJCO0VBQUVDLGdCQUFnQixFQUFFO0FBQVEsQ0FBQyxFQUNyRTtFQUFFRCxTQUFTLEVBQUUsa0NBQWtDO0VBQUVDLGdCQUFnQixFQUFFO0FBQU8sQ0FBQyxDQUM1RSJ9