parse-server 7.0.0-alpha.4 → 7.0.0-alpha.6

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.
@@ -189,7 +189,7 @@ class UserController extends _AdaptableController.default {
189
189
  * @param user
190
190
  * @returns {*}
191
191
  */
192
- async regenerateEmailVerifyToken(user, master) {
192
+ async regenerateEmailVerifyToken(user, master, installationId, ip) {
193
193
  const {
194
194
  _email_verify_token
195
195
  } = user;
@@ -200,11 +200,16 @@ class UserController extends _AdaptableController.default {
200
200
  _email_verify_token_expires_at = _email_verify_token_expires_at.iso;
201
201
  }
202
202
  if (this.config.emailVerifyTokenReuseIfValid && this.config.emailVerifyTokenValidityDuration && _email_verify_token && new Date() < new Date(_email_verify_token_expires_at)) {
203
- return Promise.resolve();
203
+ return Promise.resolve(true);
204
204
  }
205
205
  const shouldSend = await this.setEmailVerifyToken(user, {
206
- user,
207
- master
206
+ object: _node.default.User.fromJSON(Object.assign({
207
+ className: '_User'
208
+ }, user)),
209
+ master,
210
+ installationId,
211
+ ip,
212
+ resendRequest: true
208
213
  });
209
214
  if (!shouldSend) {
210
215
  return;
@@ -214,14 +219,14 @@ class UserController extends _AdaptableController.default {
214
219
  }, user);
215
220
  }
216
221
  async resendVerificationEmail(username, req) {
217
- var _req$auth2;
222
+ var _req$auth2, _req$auth3;
218
223
  const aUser = await this.getUserIfNeeded({
219
224
  username: username
220
225
  });
221
226
  if (!aUser || aUser.emailVerified) {
222
227
  throw undefined;
223
228
  }
224
- const generate = await this.regenerateEmailVerifyToken(aUser, (_req$auth2 = req.auth) === null || _req$auth2 === void 0 ? void 0 : _req$auth2.isMaster);
229
+ const generate = await this.regenerateEmailVerifyToken(aUser, (_req$auth2 = req.auth) === null || _req$auth2 === void 0 ? void 0 : _req$auth2.isMaster, (_req$auth3 = req.auth) === null || _req$auth3 === void 0 ? void 0 : _req$auth3.installationId, req.ip);
225
230
  if (generate) {
226
231
  this.sendVerificationEmail(aUser, req);
227
232
  }
@@ -361,4 +366,4 @@ function buildEmailLink(destination, username, token, config) {
361
366
  }
362
367
  var _default = UserController;
363
368
  exports.default = _default;
364
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_cryptoUtils","require","_triggers","_AdaptableController","_interopRequireDefault","_MailAdapter","_rest","_node","_AccountLockout","_Config","obj","__esModule","default","ownKeys","object","enumerableOnly","keys","Object","getOwnPropertySymbols","symbols","filter","sym","getOwnPropertyDescriptor","enumerable","push","apply","_objectSpread","target","i","arguments","length","source","forEach","key","_defineProperty","getOwnPropertyDescriptors","defineProperties","defineProperty","value","_toPropertyKey","configurable","writable","arg","_toPrimitive","String","input","hint","prim","Symbol","toPrimitive","undefined","res","call","TypeError","Number","RestQuery","Auth","UserController","AdaptableController","constructor","adapter","appId","options","config","Config","get","validateAdapter","shouldVerifyEmails","expectedAdapterType","MailAdapter","verifyUserEmails","setEmailVerifyToken","user","req","storage","shouldSendEmail","Promise","resolve","sendVerificationEmail","_email_verify_token","randomString","fieldsChangedByTrigger","includes","emailVerified","emailVerifyTokenValidityDuration","_email_verify_token_expires_at","Parse","_encode","generateEmailVerifyTokenExpiresAt","verifyEmail","username","token","query","updateFields","__op","$gt","Date","maintenanceAuth","maintenance","findUserForEmailVerification","method","Method","auth","className","restWhere","execute","then","result","results","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","_req$auth","response","fromJSON","isMaster","link","buildEmailLink","verifyEmailURL","appName","inflate","sendMail","defaultVerificationEmail","regenerateEmailVerifyToken","emailVerifyTokenReuseIfValid","shouldSend","resendVerificationEmail","_req$auth2","aUser","generate","setPasswordResetToken","generatePasswordResetTokenExpiresAt","$or","$exists","sendPasswordResetEmail","resetTokenReuseIfValid","requestResetPasswordURL","defaultResetPasswordEmail","updatePassword","password","updateUserPassword","accountLockoutPolicy","AccountLockout","unlockAccount","catch","error","message","reject","text","to","subject","exports","destination","usernameAndToken","parseFrameURL","destinationWithoutHost","replace","publicServerURL","_default"],"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    const shouldSendEmail =\n      this.shouldVerifyEmails === true ||\n      (typeof this.shouldVerifyEmails === 'function' &&\n        (await Promise.resolve(this.shouldVerifyEmails(req))) === true);\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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"}
369
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_cryptoUtils","require","_triggers","_AdaptableController","_interopRequireDefault","_MailAdapter","_rest","_node","_AccountLockout","_Config","obj","__esModule","default","ownKeys","object","enumerableOnly","keys","Object","getOwnPropertySymbols","symbols","filter","sym","getOwnPropertyDescriptor","enumerable","push","apply","_objectSpread","target","i","arguments","length","source","forEach","key","_defineProperty","getOwnPropertyDescriptors","defineProperties","defineProperty","value","_toPropertyKey","configurable","writable","arg","_toPrimitive","String","input","hint","prim","Symbol","toPrimitive","undefined","res","call","TypeError","Number","RestQuery","Auth","UserController","AdaptableController","constructor","adapter","appId","options","config","Config","get","validateAdapter","shouldVerifyEmails","expectedAdapterType","MailAdapter","verifyUserEmails","setEmailVerifyToken","user","req","storage","shouldSendEmail","Promise","resolve","sendVerificationEmail","_email_verify_token","randomString","fieldsChangedByTrigger","includes","emailVerified","emailVerifyTokenValidityDuration","_email_verify_token_expires_at","Parse","_encode","generateEmailVerifyTokenExpiresAt","verifyEmail","username","token","query","updateFields","__op","$gt","Date","maintenanceAuth","maintenance","findUserForEmailVerification","method","Method","auth","className","restWhere","execute","then","result","results","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","_req$auth","response","fromJSON","isMaster","link","buildEmailLink","verifyEmailURL","appName","inflate","sendMail","defaultVerificationEmail","regenerateEmailVerifyToken","installationId","ip","emailVerifyTokenReuseIfValid","shouldSend","User","assign","resendRequest","resendVerificationEmail","_req$auth2","_req$auth3","aUser","generate","setPasswordResetToken","generatePasswordResetTokenExpiresAt","$or","$exists","sendPasswordResetEmail","resetTokenReuseIfValid","requestResetPasswordURL","defaultResetPasswordEmail","updatePassword","password","updateUserPassword","accountLockoutPolicy","AccountLockout","unlockAccount","catch","error","message","reject","text","to","subject","exports","destination","usernameAndToken","parseFrameURL","destinationWithoutHost","replace","publicServerURL","_default"],"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    const shouldSendEmail =\n      this.shouldVerifyEmails === true ||\n      (typeof this.shouldVerifyEmails === 'function' &&\n        (await Promise.resolve(this.shouldVerifyEmails(req))) === true);\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, installationId, ip) {\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(true);\n    }\n    const shouldSend = await this.setEmailVerifyToken(user, {\n      object: Parse.User.fromJSON(Object.assign({ className: '_User' }, user)),\n      master,\n      installationId,\n      ip,\n      resendRequest: true\n    });\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, req.auth?.installationId, req.ip);\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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"}
@@ -410,7 +410,7 @@ class UsersRouter extends _ClassesRouter.default {
410
410
  }
411
411
  const results = await req.config.database.find('_User', {
412
412
  email: email
413
- });
413
+ }, {}, _Auth.default.maintenance(req.config));
414
414
  if (!results.length || results.length < 1) {
415
415
  throw new _node.default.Error(_node.default.Error.EMAIL_NOT_FOUND, `No user found with email ${email}`);
416
416
  }
@@ -422,7 +422,7 @@ class UsersRouter extends _ClassesRouter.default {
422
422
  throw new _node.default.Error(_node.default.Error.OTHER_CAUSE, `Email ${email} is already verified.`);
423
423
  }
424
424
  const userController = req.config.userController;
425
- const send = await userController.regenerateEmailVerifyToken(user, req.auth.isMaster);
425
+ const send = await userController.regenerateEmailVerifyToken(user, req.auth.isMaster, req.auth.installationId, req.ip);
426
426
  if (send) {
427
427
  userController.sendVerificationEmail(user, req);
428
428
  }
@@ -589,4 +589,4 @@ class UsersRouter extends _ClassesRouter.default {
589
589
  exports.UsersRouter = UsersRouter;
590
590
  var _default = UsersRouter;
591
591
  exports.default = _default;
592
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_node","_interopRequireDefault","require","_Config","_AccountLockout","_ClassesRouter","_rest","_Auth","_password","_triggers","_middlewares","_RestWrite","_logger","obj","__esModule","default","ownKeys","object","enumerableOnly","keys","Object","getOwnPropertySymbols","symbols","filter","sym","getOwnPropertyDescriptor","enumerable","push","apply","_objectSpread","target","i","arguments","length","source","forEach","key","_defineProperty","getOwnPropertyDescriptors","defineProperties","defineProperty","value","_toPropertyKey","configurable","writable","arg","_toPrimitive","String","input","hint","prim","Symbol","toPrimitive","undefined","res","call","TypeError","Number","UsersRouter","ClassesRouter","className","removeHiddenProperties","prototype","hasOwnProperty","test","_sanitizeAuthData","user","password","authData","provider","_authenticateUserFromRequest","req","Promise","resolve","reject","payload","body","username","query","email","Parse","Error","USERNAME_MISSING","PASSWORD_MISSING","OBJECT_NOT_FOUND","isValidPassword","$or","config","database","find","Auth","maintenance","then","results","loggerController","warn","passwordCrypto","compare","correct","accountLockoutPolicy","AccountLockout","handleLoginAttempt","auth","isMaster","ACL","request","master","ip","installationId","User","fromJSON","assign","verifyUserEmails","preventLoginWithUnverifiedEmail","emailVerified","EMAIL_NOT_FOUND","catch","error","handleMe","info","sessionToken","INVALID_SESSION_TOKEN","rest","include","clientSDK","context","response","handleLogIn","checkIfUserHasProvidedConfiguredProvidersForLogin","authDataResponse","validatedAuthData","handleAuthDataValidation","RestWrite","objectId","passwordPolicy","maxPasswordAge","changedAt","_password_changed_at","Date","update","_encode","__type","iso","expiresAt","getTime","filesController","expandFilesInObject","maybeRunTrigger","TriggerTypes","beforeLogin","sessionData","createSession","userId","createdWith","action","authProvider","afterLoginUser","afterLogin","authDataManager","runAfterFind","handleLogInAs","OPERATION_FORBIDDEN","INVALID_VALUE","queryResults","handleVerifyPassword","handleLogOut","success","records","del","afterLogout","Session","_throwOnBadEmailConfig","Config","validateEmailConfiguration","emailAdapter","userController","adapter","appName","publicServerURL","emailVerifyTokenValidityDuration","emailVerifyTokenReuseIfValid","e","INTERNAL_SERVER_ERROR","handleResetRequest","EMAIL_MISSING","INVALID_EMAIL_ADDRESS","sendPasswordResetEmail","err","code","_req$config$passwordP","resetPasswordSuccessOnInvalidEmail","message","handleVerificationEmailRequest","OTHER_CAUSE","send","regenerateEmailVerifyToken","sendVerificationEmail","handleChallenge","challengeData","parseUser","id","findUsersWithAuthData","getRequestObject","isChallenge","validator","getValidatorForProvider","validatorResponse","logger","acc","sort","authAdapter","challenge","providerChallengeResponse","resolveError","SCRIPT_FAILED","userString","JSON","stringify","authenticationStep","mountRoutes","route","handleFind","promiseEnsureIdempotency","handleCreate","handleGet","handleUpdate","handleDelete","exports","_default"],"sources":["../../src/Routers/UsersRouter.js"],"sourcesContent":["// These methods handle the User-related routes.\n\nimport Parse from 'parse/node';\nimport Config from '../Config';\nimport AccountLockout from '../AccountLockout';\nimport ClassesRouter from './ClassesRouter';\nimport rest from '../rest';\nimport Auth from '../Auth';\nimport passwordCrypto from '../password';\nimport {\n  maybeRunTrigger,\n  Types as TriggerTypes,\n  getRequestObject,\n  resolveError,\n} from '../triggers';\nimport { promiseEnsureIdempotency } from '../middlewares';\nimport RestWrite from '../RestWrite';\nimport { logger } from '../logger';\n\nexport class UsersRouter extends ClassesRouter {\n  className() {\n    return '_User';\n  }\n\n  /**\n   * Removes all \"_\" prefixed properties from an object, except \"__type\"\n   * @param {Object} obj An object.\n   */\n  static removeHiddenProperties(obj) {\n    for (var key in obj) {\n      if (Object.prototype.hasOwnProperty.call(obj, key)) {\n        // Regexp comes from Parse.Object.prototype.validate\n        if (key !== '__type' && !/^[A-Za-z][0-9A-Za-z_]*$/.test(key)) {\n          delete obj[key];\n        }\n      }\n    }\n  }\n\n  /**\n   * After retrieving a user directly from the database, we need to remove the\n   * password from the object (for security), and fix an issue some SDKs have\n   * with null values\n   */\n  _sanitizeAuthData(user) {\n    delete user.password;\n\n    // Sometimes the authData still has null on that keys\n    // https://github.com/parse-community/parse-server/issues/935\n    if (user.authData) {\n      Object.keys(user.authData).forEach(provider => {\n        if (user.authData[provider] === null) {\n          delete user.authData[provider];\n        }\n      });\n      if (Object.keys(user.authData).length == 0) {\n        delete user.authData;\n      }\n    }\n  }\n\n  /**\n   * Validates a password request in login and verifyPassword\n   * @param {Object} req The request\n   * @returns {Object} User object\n   * @private\n   */\n  _authenticateUserFromRequest(req) {\n    return new Promise((resolve, reject) => {\n      // Use query parameters instead if provided in url\n      let payload = req.body;\n      if (\n        (!payload.username && req.query && req.query.username) ||\n        (!payload.email && req.query && req.query.email)\n      ) {\n        payload = req.query;\n      }\n      const { username, email, password } = payload;\n\n      // TODO: use the right error codes / descriptions.\n      if (!username && !email) {\n        throw new Parse.Error(Parse.Error.USERNAME_MISSING, 'username/email is required.');\n      }\n      if (!password) {\n        throw new Parse.Error(Parse.Error.PASSWORD_MISSING, 'password is required.');\n      }\n      if (\n        typeof password !== 'string' ||\n        (email && typeof email !== 'string') ||\n        (username && typeof username !== 'string')\n      ) {\n        throw new Parse.Error(Parse.Error.OBJECT_NOT_FOUND, 'Invalid username/password.');\n      }\n\n      let user;\n      let isValidPassword = false;\n      let query;\n      if (email && username) {\n        query = { email, username };\n      } else if (email) {\n        query = { email };\n      } else {\n        query = { $or: [{ username }, { email: username }] };\n      }\n      return req.config.database\n        .find('_User', query, {}, Auth.maintenance(req.config))\n        .then(results => {\n          if (!results.length) {\n            throw new Parse.Error(Parse.Error.OBJECT_NOT_FOUND, 'Invalid username/password.');\n          }\n\n          if (results.length > 1) {\n            // corner case where user1 has username == user2 email\n            req.config.loggerController.warn(\n              \"There is a user which email is the same as another user's username, logging in based on username\"\n            );\n            user = results.filter(user => user.username === username)[0];\n          } else {\n            user = results[0];\n          }\n\n          return passwordCrypto.compare(password, user.password);\n        })\n        .then(correct => {\n          isValidPassword = correct;\n          const accountLockoutPolicy = new AccountLockout(user, req.config);\n          return accountLockoutPolicy.handleLoginAttempt(isValidPassword);\n        })\n        .then(async () => {\n          if (!isValidPassword) {\n            throw new Parse.Error(Parse.Error.OBJECT_NOT_FOUND, 'Invalid username/password.');\n          }\n          // Ensure the user isn't locked out\n          // A locked out user won't be able to login\n          // To lock a user out, just set the ACL to `masterKey` only  ({}).\n          // Empty ACL is OK\n          if (!req.auth.isMaster && user.ACL && Object.keys(user.ACL).length == 0) {\n            throw new Parse.Error(Parse.Error.OBJECT_NOT_FOUND, 'Invalid username/password.');\n          }\n          // Create request object for verification functions\n          const request = {\n            master: req.auth.isMaster,\n            ip: req.config.ip,\n            installationId: req.auth.installationId,\n            object: Parse.User.fromJSON(Object.assign({ className: '_User' }, user)),\n          };\n          // Get verification conditions which can be booleans or functions; the purpose of this async/await\n          // structure is to avoid unnecessarily executing subsequent functions if previous ones fail in the\n          // conditional statement below, as a developer may decide to execute expensive operations in them\n          const verifyUserEmails = async () => req.config.verifyUserEmails === true || (typeof req.config.verifyUserEmails === 'function' && await Promise.resolve(req.config.verifyUserEmails(request)) === true);\n          const preventLoginWithUnverifiedEmail = async () => req.config.preventLoginWithUnverifiedEmail === true || (typeof req.config.preventLoginWithUnverifiedEmail === 'function' && await Promise.resolve(req.config.preventLoginWithUnverifiedEmail(request)) === true);\n          if (await verifyUserEmails() && await preventLoginWithUnverifiedEmail() && !user.emailVerified) {\n            throw new Parse.Error(Parse.Error.EMAIL_NOT_FOUND, 'User email is not verified.');\n          }\n\n          this._sanitizeAuthData(user);\n\n          return resolve(user);\n        })\n        .catch(error => {\n          return reject(error);\n        });\n    });\n  }\n\n  handleMe(req) {\n    if (!req.info || !req.info.sessionToken) {\n      throw new Parse.Error(Parse.Error.INVALID_SESSION_TOKEN, 'Invalid session token');\n    }\n    const sessionToken = req.info.sessionToken;\n    return rest\n      .find(\n        req.config,\n        Auth.master(req.config),\n        '_Session',\n        { sessionToken },\n        { include: 'user' },\n        req.info.clientSDK,\n        req.info.context\n      )\n      .then(response => {\n        if (!response.results || response.results.length == 0 || !response.results[0].user) {\n          throw new Parse.Error(Parse.Error.INVALID_SESSION_TOKEN, 'Invalid session token');\n        } else {\n          const user = response.results[0].user;\n          // Send token back on the login, because SDKs expect that.\n          user.sessionToken = sessionToken;\n\n          // Remove hidden properties.\n          UsersRouter.removeHiddenProperties(user);\n          return { response: user };\n        }\n      });\n  }\n\n  async handleLogIn(req) {\n    const user = await this._authenticateUserFromRequest(req);\n    const authData = req.body && req.body.authData;\n    // Check if user has provided their required auth providers\n    Auth.checkIfUserHasProvidedConfiguredProvidersForLogin(\n      req,\n      authData,\n      user.authData,\n      req.config\n    );\n\n    let authDataResponse;\n    let validatedAuthData;\n    if (authData) {\n      const res = await Auth.handleAuthDataValidation(\n        authData,\n        new RestWrite(\n          req.config,\n          req.auth,\n          '_User',\n          { objectId: user.objectId },\n          req.body,\n          user,\n          req.info.clientSDK,\n          req.info.context\n        ),\n        user\n      );\n      authDataResponse = res.authDataResponse;\n      validatedAuthData = res.authData;\n    }\n\n    // handle password expiry policy\n    if (req.config.passwordPolicy && req.config.passwordPolicy.maxPasswordAge) {\n      let changedAt = user._password_changed_at;\n\n      if (!changedAt) {\n        // password was created before expiry policy was enabled.\n        // simply update _User object so that it will start enforcing from now\n        changedAt = new Date();\n        req.config.database.update(\n          '_User',\n          { username: user.username },\n          { _password_changed_at: Parse._encode(changedAt) }\n        );\n      } else {\n        // check whether the password has expired\n        if (changedAt.__type == 'Date') {\n          changedAt = new Date(changedAt.iso);\n        }\n        // Calculate the expiry time.\n        const expiresAt = new Date(\n          changedAt.getTime() + 86400000 * req.config.passwordPolicy.maxPasswordAge\n        );\n        if (expiresAt < new Date())\n          // fail of current time is past password expiry time\n          throw new Parse.Error(\n            Parse.Error.OBJECT_NOT_FOUND,\n            'Your password has expired. Please reset your password.'\n          );\n      }\n    }\n\n    // Remove hidden properties.\n    UsersRouter.removeHiddenProperties(user);\n\n    req.config.filesController.expandFilesInObject(req.config, user);\n\n    // Before login trigger; throws if failure\n    await maybeRunTrigger(\n      TriggerTypes.beforeLogin,\n      req.auth,\n      Parse.User.fromJSON(Object.assign({ className: '_User' }, user)),\n      null,\n      req.config,\n      req.info.context\n    );\n\n    // If we have some new validated authData update directly\n    if (validatedAuthData && Object.keys(validatedAuthData).length) {\n      await req.config.database.update(\n        '_User',\n        { objectId: user.objectId },\n        { authData: validatedAuthData },\n        {}\n      );\n    }\n\n    const { sessionData, createSession } = RestWrite.createSession(req.config, {\n      userId: user.objectId,\n      createdWith: {\n        action: 'login',\n        authProvider: 'password',\n      },\n      installationId: req.info.installationId,\n    });\n\n    user.sessionToken = sessionData.sessionToken;\n\n    await createSession();\n\n    const afterLoginUser = Parse.User.fromJSON(Object.assign({ className: '_User' }, user));\n    await maybeRunTrigger(\n      TriggerTypes.afterLogin,\n      { ...req.auth, user: afterLoginUser },\n      afterLoginUser,\n      null,\n      req.config,\n      req.info.context\n    );\n\n    if (authDataResponse) {\n      user.authDataResponse = authDataResponse;\n    }\n    await req.config.authDataManager.runAfterFind(req, user.authData);\n\n    return { response: user };\n  }\n\n  /**\n   * This allows master-key clients to create user sessions without access to\n   * user credentials. This enables systems that can authenticate access another\n   * way (API key, app administrators) to act on a user's behalf.\n   *\n   * We create a new session rather than looking for an existing session; we\n   * want this to work in situations where the user is logged out on all\n   * devices, since this can be used by automated systems acting on the user's\n   * behalf.\n   *\n   * For the moment, we're omitting event hooks and lockout checks, since\n   * immediate use cases suggest /loginAs could be used for semantically\n   * different reasons from /login\n   */\n  async handleLogInAs(req) {\n    if (!req.auth.isMaster) {\n      throw new Parse.Error(Parse.Error.OPERATION_FORBIDDEN, 'master key is required');\n    }\n\n    const userId = req.body.userId || req.query.userId;\n    if (!userId) {\n      throw new Parse.Error(\n        Parse.Error.INVALID_VALUE,\n        'userId must not be empty, null, or undefined'\n      );\n    }\n\n    const queryResults = await req.config.database.find('_User', { objectId: userId });\n    const user = queryResults[0];\n    if (!user) {\n      throw new Parse.Error(Parse.Error.OBJECT_NOT_FOUND, 'user not found');\n    }\n\n    this._sanitizeAuthData(user);\n\n    const { sessionData, createSession } = RestWrite.createSession(req.config, {\n      userId,\n      createdWith: {\n        action: 'login',\n        authProvider: 'masterkey',\n      },\n      installationId: req.info.installationId,\n    });\n\n    user.sessionToken = sessionData.sessionToken;\n\n    await createSession();\n\n    return { response: user };\n  }\n\n  handleVerifyPassword(req) {\n    return this._authenticateUserFromRequest(req)\n      .then(user => {\n        // Remove hidden properties.\n        UsersRouter.removeHiddenProperties(user);\n\n        return { response: user };\n      })\n      .catch(error => {\n        throw error;\n      });\n  }\n\n  async handleLogOut(req) {\n    const success = { response: {} };\n    if (req.info && req.info.sessionToken) {\n      const records = await rest.find(\n        req.config,\n        Auth.master(req.config),\n        '_Session',\n        { sessionToken: req.info.sessionToken },\n        undefined,\n        req.info.clientSDK,\n        req.info.context\n      );\n      if (records.results && records.results.length) {\n        await rest.del(\n          req.config,\n          Auth.master(req.config),\n          '_Session',\n          records.results[0].objectId,\n          req.info.context\n        );\n        await maybeRunTrigger(\n          TriggerTypes.afterLogout,\n          req.auth,\n          Parse.Session.fromJSON(Object.assign({ className: '_Session' }, records.results[0])),\n          null,\n          req.config\n        );\n      }\n    }\n    return success;\n  }\n\n  _throwOnBadEmailConfig(req) {\n    try {\n      Config.validateEmailConfiguration({\n        emailAdapter: req.config.userController.adapter,\n        appName: req.config.appName,\n        publicServerURL: req.config.publicServerURL,\n        emailVerifyTokenValidityDuration: req.config.emailVerifyTokenValidityDuration,\n        emailVerifyTokenReuseIfValid: req.config.emailVerifyTokenReuseIfValid,\n      });\n    } catch (e) {\n      if (typeof e === 'string') {\n        // Maybe we need a Bad Configuration error, but the SDKs won't understand it. For now, Internal Server Error.\n        throw new Parse.Error(\n          Parse.Error.INTERNAL_SERVER_ERROR,\n          'An appName, publicServerURL, and emailAdapter are required for password reset and email verification functionality.'\n        );\n      } else {\n        throw e;\n      }\n    }\n  }\n\n  async handleResetRequest(req) {\n    this._throwOnBadEmailConfig(req);\n\n    const { email } = req.body;\n    if (!email) {\n      throw new Parse.Error(Parse.Error.EMAIL_MISSING, 'you must provide an email');\n    }\n    if (typeof email !== 'string') {\n      throw new Parse.Error(\n        Parse.Error.INVALID_EMAIL_ADDRESS,\n        'you must provide a valid email string'\n      );\n    }\n    const userController = req.config.userController;\n    try {\n      await userController.sendPasswordResetEmail(email);\n      return {\n        response: {},\n      };\n    } catch (err) {\n      if (err.code === Parse.Error.OBJECT_NOT_FOUND) {\n        if (req.config.passwordPolicy?.resetPasswordSuccessOnInvalidEmail ?? true) {\n          return {\n            response: {},\n          };\n        }\n        err.message = `A user with that email does not exist.`;\n      }\n      throw err;\n    }\n  }\n\n  async handleVerificationEmailRequest(req) {\n    this._throwOnBadEmailConfig(req);\n\n    const { email } = req.body;\n    if (!email) {\n      throw new Parse.Error(Parse.Error.EMAIL_MISSING, 'you must provide an email');\n    }\n    if (typeof email !== 'string') {\n      throw new Parse.Error(\n        Parse.Error.INVALID_EMAIL_ADDRESS,\n        'you must provide a valid email string'\n      );\n    }\n\n    const results = await req.config.database.find('_User', { email: email });\n    if (!results.length || results.length < 1) {\n      throw new Parse.Error(Parse.Error.EMAIL_NOT_FOUND, `No user found with email ${email}`);\n    }\n    const user = results[0];\n\n    // remove password field, messes with saving on postgres\n    delete user.password;\n\n    if (user.emailVerified) {\n      throw new Parse.Error(Parse.Error.OTHER_CAUSE, `Email ${email} is already verified.`);\n    }\n\n    const userController = req.config.userController;\n    const send = await userController.regenerateEmailVerifyToken(user, req.auth.isMaster);\n    if (send) {\n      userController.sendVerificationEmail(user, req);\n    }\n    return { response: {} };\n  }\n\n  async handleChallenge(req) {\n    const { username, email, password, authData, challengeData } = req.body;\n\n    // if username or email provided with password try to authenticate the user by username\n    let user;\n    if (username || email) {\n      if (!password) {\n        throw new Parse.Error(\n          Parse.Error.OTHER_CAUSE,\n          'You provided username or email, you need to also provide password.'\n        );\n      }\n      user = await this._authenticateUserFromRequest(req);\n    }\n\n    if (!challengeData) {\n      throw new Parse.Error(Parse.Error.OTHER_CAUSE, 'Nothing to challenge.');\n    }\n\n    if (typeof challengeData !== 'object') {\n      throw new Parse.Error(Parse.Error.OTHER_CAUSE, 'challengeData should be an object.');\n    }\n\n    let request;\n    let parseUser;\n\n    // Try to find user by authData\n    if (authData) {\n      if (typeof authData !== 'object') {\n        throw new Parse.Error(Parse.Error.OTHER_CAUSE, 'authData should be an object.');\n      }\n      if (user) {\n        throw new Parse.Error(\n          Parse.Error.OTHER_CAUSE,\n          'You cannot provide username/email and authData, only use one identification method.'\n        );\n      }\n\n      if (Object.keys(authData).filter(key => authData[key].id).length > 1) {\n        throw new Parse.Error(\n          Parse.Error.OTHER_CAUSE,\n          'You cannot provide more than one authData provider with an id.'\n        );\n      }\n\n      const results = await Auth.findUsersWithAuthData(req.config, authData);\n\n      try {\n        if (!results[0] || results.length > 1) {\n          throw new Parse.Error(Parse.Error.OBJECT_NOT_FOUND, 'User not found.');\n        }\n        // Find the provider used to find the user\n        const provider = Object.keys(authData).find(key => authData[key].id);\n\n        parseUser = Parse.User.fromJSON({ className: '_User', ...results[0] });\n        request = getRequestObject(undefined, req.auth, parseUser, parseUser, req.config);\n        request.isChallenge = true;\n        // Validate authData used to identify the user to avoid brute-force attack on `id`\n        const { validator } = req.config.authDataManager.getValidatorForProvider(provider);\n        const validatorResponse = await validator(authData[provider], req, parseUser, request);\n        if (validatorResponse && validatorResponse.validator) {\n          await validatorResponse.validator();\n        }\n      } catch (e) {\n        // Rewrite the error to avoid guess id attack\n        logger.error(e);\n        throw new Parse.Error(Parse.Error.OBJECT_NOT_FOUND, 'User not found.');\n      }\n    }\n\n    if (!parseUser) {\n      parseUser = user ? Parse.User.fromJSON({ className: '_User', ...user }) : undefined;\n    }\n\n    if (!request) {\n      request = getRequestObject(undefined, req.auth, parseUser, parseUser, req.config);\n      request.isChallenge = true;\n    }\n    const acc = {};\n    // Execute challenge step-by-step with consistent order for better error feedback\n    // and to avoid to trigger others challenges if one of them fails\n    for (const provider of Object.keys(challengeData).sort()) {\n      try {\n        const authAdapter = req.config.authDataManager.getValidatorForProvider(provider);\n        if (!authAdapter) {\n          continue;\n        }\n        const {\n          adapter: { challenge },\n        } = authAdapter;\n        if (typeof challenge === 'function') {\n          const providerChallengeResponse = await challenge(\n            challengeData[provider],\n            authData && authData[provider],\n            req.config.auth[provider],\n            request\n          );\n          acc[provider] = providerChallengeResponse || true;\n        }\n      } catch (err) {\n        const e = resolveError(err, {\n          code: Parse.Error.SCRIPT_FAILED,\n          message: 'Challenge failed. Unknown error.',\n        });\n        const userString = req.auth && req.auth.user ? req.auth.user.id : undefined;\n        logger.error(\n          `Failed running auth step challenge for ${provider} for user ${userString} with Error: ` +\n            JSON.stringify(e),\n          {\n            authenticationStep: 'challenge',\n            error: e,\n            user: userString,\n            provider,\n          }\n        );\n        throw e;\n      }\n    }\n    return { response: { challengeData: acc } };\n  }\n\n  mountRoutes() {\n    this.route('GET', '/users', req => {\n      return this.handleFind(req);\n    });\n    this.route('POST', '/users', promiseEnsureIdempotency, req => {\n      return this.handleCreate(req);\n    });\n    this.route('GET', '/users/me', req => {\n      return this.handleMe(req);\n    });\n    this.route('GET', '/users/:objectId', req => {\n      return this.handleGet(req);\n    });\n    this.route('PUT', '/users/:objectId', promiseEnsureIdempotency, req => {\n      return this.handleUpdate(req);\n    });\n    this.route('DELETE', '/users/:objectId', req => {\n      return this.handleDelete(req);\n    });\n    this.route('GET', '/login', req => {\n      return this.handleLogIn(req);\n    });\n    this.route('POST', '/login', req => {\n      return this.handleLogIn(req);\n    });\n    this.route('POST', '/loginAs', req => {\n      return this.handleLogInAs(req);\n    });\n    this.route('POST', '/logout', req => {\n      return this.handleLogOut(req);\n    });\n    this.route('POST', '/requestPasswordReset', req => {\n      return this.handleResetRequest(req);\n    });\n    this.route('POST', '/verificationEmailRequest', req => {\n      return this.handleVerificationEmailRequest(req);\n    });\n    this.route('GET', '/verifyPassword', req => {\n      return this.handleVerifyPassword(req);\n    });\n    this.route('POST', '/challenge', req => {\n      return this.handleChallenge(req);\n    });\n  }\n}\n\nexport default UsersRouter;\n"],"mappings":"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"}
592
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_node","_interopRequireDefault","require","_Config","_AccountLockout","_ClassesRouter","_rest","_Auth","_password","_triggers","_middlewares","_RestWrite","_logger","obj","__esModule","default","ownKeys","object","enumerableOnly","keys","Object","getOwnPropertySymbols","symbols","filter","sym","getOwnPropertyDescriptor","enumerable","push","apply","_objectSpread","target","i","arguments","length","source","forEach","key","_defineProperty","getOwnPropertyDescriptors","defineProperties","defineProperty","value","_toPropertyKey","configurable","writable","arg","_toPrimitive","String","input","hint","prim","Symbol","toPrimitive","undefined","res","call","TypeError","Number","UsersRouter","ClassesRouter","className","removeHiddenProperties","prototype","hasOwnProperty","test","_sanitizeAuthData","user","password","authData","provider","_authenticateUserFromRequest","req","Promise","resolve","reject","payload","body","username","query","email","Parse","Error","USERNAME_MISSING","PASSWORD_MISSING","OBJECT_NOT_FOUND","isValidPassword","$or","config","database","find","Auth","maintenance","then","results","loggerController","warn","passwordCrypto","compare","correct","accountLockoutPolicy","AccountLockout","handleLoginAttempt","auth","isMaster","ACL","request","master","ip","installationId","User","fromJSON","assign","verifyUserEmails","preventLoginWithUnverifiedEmail","emailVerified","EMAIL_NOT_FOUND","catch","error","handleMe","info","sessionToken","INVALID_SESSION_TOKEN","rest","include","clientSDK","context","response","handleLogIn","checkIfUserHasProvidedConfiguredProvidersForLogin","authDataResponse","validatedAuthData","handleAuthDataValidation","RestWrite","objectId","passwordPolicy","maxPasswordAge","changedAt","_password_changed_at","Date","update","_encode","__type","iso","expiresAt","getTime","filesController","expandFilesInObject","maybeRunTrigger","TriggerTypes","beforeLogin","sessionData","createSession","userId","createdWith","action","authProvider","afterLoginUser","afterLogin","authDataManager","runAfterFind","handleLogInAs","OPERATION_FORBIDDEN","INVALID_VALUE","queryResults","handleVerifyPassword","handleLogOut","success","records","del","afterLogout","Session","_throwOnBadEmailConfig","Config","validateEmailConfiguration","emailAdapter","userController","adapter","appName","publicServerURL","emailVerifyTokenValidityDuration","emailVerifyTokenReuseIfValid","e","INTERNAL_SERVER_ERROR","handleResetRequest","EMAIL_MISSING","INVALID_EMAIL_ADDRESS","sendPasswordResetEmail","err","code","_req$config$passwordP","resetPasswordSuccessOnInvalidEmail","message","handleVerificationEmailRequest","OTHER_CAUSE","send","regenerateEmailVerifyToken","sendVerificationEmail","handleChallenge","challengeData","parseUser","id","findUsersWithAuthData","getRequestObject","isChallenge","validator","getValidatorForProvider","validatorResponse","logger","acc","sort","authAdapter","challenge","providerChallengeResponse","resolveError","SCRIPT_FAILED","userString","JSON","stringify","authenticationStep","mountRoutes","route","handleFind","promiseEnsureIdempotency","handleCreate","handleGet","handleUpdate","handleDelete","exports","_default"],"sources":["../../src/Routers/UsersRouter.js"],"sourcesContent":["// These methods handle the User-related routes.\n\nimport Parse from 'parse/node';\nimport Config from '../Config';\nimport AccountLockout from '../AccountLockout';\nimport ClassesRouter from './ClassesRouter';\nimport rest from '../rest';\nimport Auth from '../Auth';\nimport passwordCrypto from '../password';\nimport {\n  maybeRunTrigger,\n  Types as TriggerTypes,\n  getRequestObject,\n  resolveError,\n} from '../triggers';\nimport { promiseEnsureIdempotency } from '../middlewares';\nimport RestWrite from '../RestWrite';\nimport { logger } from '../logger';\n\nexport class UsersRouter extends ClassesRouter {\n  className() {\n    return '_User';\n  }\n\n  /**\n   * Removes all \"_\" prefixed properties from an object, except \"__type\"\n   * @param {Object} obj An object.\n   */\n  static removeHiddenProperties(obj) {\n    for (var key in obj) {\n      if (Object.prototype.hasOwnProperty.call(obj, key)) {\n        // Regexp comes from Parse.Object.prototype.validate\n        if (key !== '__type' && !/^[A-Za-z][0-9A-Za-z_]*$/.test(key)) {\n          delete obj[key];\n        }\n      }\n    }\n  }\n\n  /**\n   * After retrieving a user directly from the database, we need to remove the\n   * password from the object (for security), and fix an issue some SDKs have\n   * with null values\n   */\n  _sanitizeAuthData(user) {\n    delete user.password;\n\n    // Sometimes the authData still has null on that keys\n    // https://github.com/parse-community/parse-server/issues/935\n    if (user.authData) {\n      Object.keys(user.authData).forEach(provider => {\n        if (user.authData[provider] === null) {\n          delete user.authData[provider];\n        }\n      });\n      if (Object.keys(user.authData).length == 0) {\n        delete user.authData;\n      }\n    }\n  }\n\n  /**\n   * Validates a password request in login and verifyPassword\n   * @param {Object} req The request\n   * @returns {Object} User object\n   * @private\n   */\n  _authenticateUserFromRequest(req) {\n    return new Promise((resolve, reject) => {\n      // Use query parameters instead if provided in url\n      let payload = req.body;\n      if (\n        (!payload.username && req.query && req.query.username) ||\n        (!payload.email && req.query && req.query.email)\n      ) {\n        payload = req.query;\n      }\n      const { username, email, password } = payload;\n\n      // TODO: use the right error codes / descriptions.\n      if (!username && !email) {\n        throw new Parse.Error(Parse.Error.USERNAME_MISSING, 'username/email is required.');\n      }\n      if (!password) {\n        throw new Parse.Error(Parse.Error.PASSWORD_MISSING, 'password is required.');\n      }\n      if (\n        typeof password !== 'string' ||\n        (email && typeof email !== 'string') ||\n        (username && typeof username !== 'string')\n      ) {\n        throw new Parse.Error(Parse.Error.OBJECT_NOT_FOUND, 'Invalid username/password.');\n      }\n\n      let user;\n      let isValidPassword = false;\n      let query;\n      if (email && username) {\n        query = { email, username };\n      } else if (email) {\n        query = { email };\n      } else {\n        query = { $or: [{ username }, { email: username }] };\n      }\n      return req.config.database\n        .find('_User', query, {}, Auth.maintenance(req.config))\n        .then(results => {\n          if (!results.length) {\n            throw new Parse.Error(Parse.Error.OBJECT_NOT_FOUND, 'Invalid username/password.');\n          }\n\n          if (results.length > 1) {\n            // corner case where user1 has username == user2 email\n            req.config.loggerController.warn(\n              \"There is a user which email is the same as another user's username, logging in based on username\"\n            );\n            user = results.filter(user => user.username === username)[0];\n          } else {\n            user = results[0];\n          }\n\n          return passwordCrypto.compare(password, user.password);\n        })\n        .then(correct => {\n          isValidPassword = correct;\n          const accountLockoutPolicy = new AccountLockout(user, req.config);\n          return accountLockoutPolicy.handleLoginAttempt(isValidPassword);\n        })\n        .then(async () => {\n          if (!isValidPassword) {\n            throw new Parse.Error(Parse.Error.OBJECT_NOT_FOUND, 'Invalid username/password.');\n          }\n          // Ensure the user isn't locked out\n          // A locked out user won't be able to login\n          // To lock a user out, just set the ACL to `masterKey` only  ({}).\n          // Empty ACL is OK\n          if (!req.auth.isMaster && user.ACL && Object.keys(user.ACL).length == 0) {\n            throw new Parse.Error(Parse.Error.OBJECT_NOT_FOUND, 'Invalid username/password.');\n          }\n          // Create request object for verification functions\n          const request = {\n            master: req.auth.isMaster,\n            ip: req.config.ip,\n            installationId: req.auth.installationId,\n            object: Parse.User.fromJSON(Object.assign({ className: '_User' }, user)),\n          };\n          // Get verification conditions which can be booleans or functions; the purpose of this async/await\n          // structure is to avoid unnecessarily executing subsequent functions if previous ones fail in the\n          // conditional statement below, as a developer may decide to execute expensive operations in them\n          const verifyUserEmails = async () => req.config.verifyUserEmails === true || (typeof req.config.verifyUserEmails === 'function' && await Promise.resolve(req.config.verifyUserEmails(request)) === true);\n          const preventLoginWithUnverifiedEmail = async () => req.config.preventLoginWithUnverifiedEmail === true || (typeof req.config.preventLoginWithUnverifiedEmail === 'function' && await Promise.resolve(req.config.preventLoginWithUnverifiedEmail(request)) === true);\n          if (await verifyUserEmails() && await preventLoginWithUnverifiedEmail() && !user.emailVerified) {\n            throw new Parse.Error(Parse.Error.EMAIL_NOT_FOUND, 'User email is not verified.');\n          }\n\n          this._sanitizeAuthData(user);\n\n          return resolve(user);\n        })\n        .catch(error => {\n          return reject(error);\n        });\n    });\n  }\n\n  handleMe(req) {\n    if (!req.info || !req.info.sessionToken) {\n      throw new Parse.Error(Parse.Error.INVALID_SESSION_TOKEN, 'Invalid session token');\n    }\n    const sessionToken = req.info.sessionToken;\n    return rest\n      .find(\n        req.config,\n        Auth.master(req.config),\n        '_Session',\n        { sessionToken },\n        { include: 'user' },\n        req.info.clientSDK,\n        req.info.context\n      )\n      .then(response => {\n        if (!response.results || response.results.length == 0 || !response.results[0].user) {\n          throw new Parse.Error(Parse.Error.INVALID_SESSION_TOKEN, 'Invalid session token');\n        } else {\n          const user = response.results[0].user;\n          // Send token back on the login, because SDKs expect that.\n          user.sessionToken = sessionToken;\n\n          // Remove hidden properties.\n          UsersRouter.removeHiddenProperties(user);\n          return { response: user };\n        }\n      });\n  }\n\n  async handleLogIn(req) {\n    const user = await this._authenticateUserFromRequest(req);\n    const authData = req.body && req.body.authData;\n    // Check if user has provided their required auth providers\n    Auth.checkIfUserHasProvidedConfiguredProvidersForLogin(\n      req,\n      authData,\n      user.authData,\n      req.config\n    );\n\n    let authDataResponse;\n    let validatedAuthData;\n    if (authData) {\n      const res = await Auth.handleAuthDataValidation(\n        authData,\n        new RestWrite(\n          req.config,\n          req.auth,\n          '_User',\n          { objectId: user.objectId },\n          req.body,\n          user,\n          req.info.clientSDK,\n          req.info.context\n        ),\n        user\n      );\n      authDataResponse = res.authDataResponse;\n      validatedAuthData = res.authData;\n    }\n\n    // handle password expiry policy\n    if (req.config.passwordPolicy && req.config.passwordPolicy.maxPasswordAge) {\n      let changedAt = user._password_changed_at;\n\n      if (!changedAt) {\n        // password was created before expiry policy was enabled.\n        // simply update _User object so that it will start enforcing from now\n        changedAt = new Date();\n        req.config.database.update(\n          '_User',\n          { username: user.username },\n          { _password_changed_at: Parse._encode(changedAt) }\n        );\n      } else {\n        // check whether the password has expired\n        if (changedAt.__type == 'Date') {\n          changedAt = new Date(changedAt.iso);\n        }\n        // Calculate the expiry time.\n        const expiresAt = new Date(\n          changedAt.getTime() + 86400000 * req.config.passwordPolicy.maxPasswordAge\n        );\n        if (expiresAt < new Date())\n          // fail of current time is past password expiry time\n          throw new Parse.Error(\n            Parse.Error.OBJECT_NOT_FOUND,\n            'Your password has expired. Please reset your password.'\n          );\n      }\n    }\n\n    // Remove hidden properties.\n    UsersRouter.removeHiddenProperties(user);\n\n    req.config.filesController.expandFilesInObject(req.config, user);\n\n    // Before login trigger; throws if failure\n    await maybeRunTrigger(\n      TriggerTypes.beforeLogin,\n      req.auth,\n      Parse.User.fromJSON(Object.assign({ className: '_User' }, user)),\n      null,\n      req.config,\n      req.info.context\n    );\n\n    // If we have some new validated authData update directly\n    if (validatedAuthData && Object.keys(validatedAuthData).length) {\n      await req.config.database.update(\n        '_User',\n        { objectId: user.objectId },\n        { authData: validatedAuthData },\n        {}\n      );\n    }\n\n    const { sessionData, createSession } = RestWrite.createSession(req.config, {\n      userId: user.objectId,\n      createdWith: {\n        action: 'login',\n        authProvider: 'password',\n      },\n      installationId: req.info.installationId,\n    });\n\n    user.sessionToken = sessionData.sessionToken;\n\n    await createSession();\n\n    const afterLoginUser = Parse.User.fromJSON(Object.assign({ className: '_User' }, user));\n    await maybeRunTrigger(\n      TriggerTypes.afterLogin,\n      { ...req.auth, user: afterLoginUser },\n      afterLoginUser,\n      null,\n      req.config,\n      req.info.context\n    );\n\n    if (authDataResponse) {\n      user.authDataResponse = authDataResponse;\n    }\n    await req.config.authDataManager.runAfterFind(req, user.authData);\n\n    return { response: user };\n  }\n\n  /**\n   * This allows master-key clients to create user sessions without access to\n   * user credentials. This enables systems that can authenticate access another\n   * way (API key, app administrators) to act on a user's behalf.\n   *\n   * We create a new session rather than looking for an existing session; we\n   * want this to work in situations where the user is logged out on all\n   * devices, since this can be used by automated systems acting on the user's\n   * behalf.\n   *\n   * For the moment, we're omitting event hooks and lockout checks, since\n   * immediate use cases suggest /loginAs could be used for semantically\n   * different reasons from /login\n   */\n  async handleLogInAs(req) {\n    if (!req.auth.isMaster) {\n      throw new Parse.Error(Parse.Error.OPERATION_FORBIDDEN, 'master key is required');\n    }\n\n    const userId = req.body.userId || req.query.userId;\n    if (!userId) {\n      throw new Parse.Error(\n        Parse.Error.INVALID_VALUE,\n        'userId must not be empty, null, or undefined'\n      );\n    }\n\n    const queryResults = await req.config.database.find('_User', { objectId: userId });\n    const user = queryResults[0];\n    if (!user) {\n      throw new Parse.Error(Parse.Error.OBJECT_NOT_FOUND, 'user not found');\n    }\n\n    this._sanitizeAuthData(user);\n\n    const { sessionData, createSession } = RestWrite.createSession(req.config, {\n      userId,\n      createdWith: {\n        action: 'login',\n        authProvider: 'masterkey',\n      },\n      installationId: req.info.installationId,\n    });\n\n    user.sessionToken = sessionData.sessionToken;\n\n    await createSession();\n\n    return { response: user };\n  }\n\n  handleVerifyPassword(req) {\n    return this._authenticateUserFromRequest(req)\n      .then(user => {\n        // Remove hidden properties.\n        UsersRouter.removeHiddenProperties(user);\n\n        return { response: user };\n      })\n      .catch(error => {\n        throw error;\n      });\n  }\n\n  async handleLogOut(req) {\n    const success = { response: {} };\n    if (req.info && req.info.sessionToken) {\n      const records = await rest.find(\n        req.config,\n        Auth.master(req.config),\n        '_Session',\n        { sessionToken: req.info.sessionToken },\n        undefined,\n        req.info.clientSDK,\n        req.info.context\n      );\n      if (records.results && records.results.length) {\n        await rest.del(\n          req.config,\n          Auth.master(req.config),\n          '_Session',\n          records.results[0].objectId,\n          req.info.context\n        );\n        await maybeRunTrigger(\n          TriggerTypes.afterLogout,\n          req.auth,\n          Parse.Session.fromJSON(Object.assign({ className: '_Session' }, records.results[0])),\n          null,\n          req.config\n        );\n      }\n    }\n    return success;\n  }\n\n  _throwOnBadEmailConfig(req) {\n    try {\n      Config.validateEmailConfiguration({\n        emailAdapter: req.config.userController.adapter,\n        appName: req.config.appName,\n        publicServerURL: req.config.publicServerURL,\n        emailVerifyTokenValidityDuration: req.config.emailVerifyTokenValidityDuration,\n        emailVerifyTokenReuseIfValid: req.config.emailVerifyTokenReuseIfValid,\n      });\n    } catch (e) {\n      if (typeof e === 'string') {\n        // Maybe we need a Bad Configuration error, but the SDKs won't understand it. For now, Internal Server Error.\n        throw new Parse.Error(\n          Parse.Error.INTERNAL_SERVER_ERROR,\n          'An appName, publicServerURL, and emailAdapter are required for password reset and email verification functionality.'\n        );\n      } else {\n        throw e;\n      }\n    }\n  }\n\n  async handleResetRequest(req) {\n    this._throwOnBadEmailConfig(req);\n\n    const { email } = req.body;\n    if (!email) {\n      throw new Parse.Error(Parse.Error.EMAIL_MISSING, 'you must provide an email');\n    }\n    if (typeof email !== 'string') {\n      throw new Parse.Error(\n        Parse.Error.INVALID_EMAIL_ADDRESS,\n        'you must provide a valid email string'\n      );\n    }\n    const userController = req.config.userController;\n    try {\n      await userController.sendPasswordResetEmail(email);\n      return {\n        response: {},\n      };\n    } catch (err) {\n      if (err.code === Parse.Error.OBJECT_NOT_FOUND) {\n        if (req.config.passwordPolicy?.resetPasswordSuccessOnInvalidEmail ?? true) {\n          return {\n            response: {},\n          };\n        }\n        err.message = `A user with that email does not exist.`;\n      }\n      throw err;\n    }\n  }\n\n  async handleVerificationEmailRequest(req) {\n    this._throwOnBadEmailConfig(req);\n\n    const { email } = req.body;\n    if (!email) {\n      throw new Parse.Error(Parse.Error.EMAIL_MISSING, 'you must provide an email');\n    }\n    if (typeof email !== 'string') {\n      throw new Parse.Error(\n        Parse.Error.INVALID_EMAIL_ADDRESS,\n        'you must provide a valid email string'\n      );\n    }\n\n    const results = await req.config.database.find('_User', { email: email }, {}, Auth.maintenance(req.config));\n    if (!results.length || results.length < 1) {\n      throw new Parse.Error(Parse.Error.EMAIL_NOT_FOUND, `No user found with email ${email}`);\n    }\n    const user = results[0];\n\n    // remove password field, messes with saving on postgres\n    delete user.password;\n\n    if (user.emailVerified) {\n      throw new Parse.Error(Parse.Error.OTHER_CAUSE, `Email ${email} is already verified.`);\n    }\n\n    const userController = req.config.userController;\n    const send = await userController.regenerateEmailVerifyToken(user, req.auth.isMaster, req.auth.installationId, req.ip);\n    if (send) {\n      userController.sendVerificationEmail(user, req);\n    }\n    return { response: {} };\n  }\n\n  async handleChallenge(req) {\n    const { username, email, password, authData, challengeData } = req.body;\n\n    // if username or email provided with password try to authenticate the user by username\n    let user;\n    if (username || email) {\n      if (!password) {\n        throw new Parse.Error(\n          Parse.Error.OTHER_CAUSE,\n          'You provided username or email, you need to also provide password.'\n        );\n      }\n      user = await this._authenticateUserFromRequest(req);\n    }\n\n    if (!challengeData) {\n      throw new Parse.Error(Parse.Error.OTHER_CAUSE, 'Nothing to challenge.');\n    }\n\n    if (typeof challengeData !== 'object') {\n      throw new Parse.Error(Parse.Error.OTHER_CAUSE, 'challengeData should be an object.');\n    }\n\n    let request;\n    let parseUser;\n\n    // Try to find user by authData\n    if (authData) {\n      if (typeof authData !== 'object') {\n        throw new Parse.Error(Parse.Error.OTHER_CAUSE, 'authData should be an object.');\n      }\n      if (user) {\n        throw new Parse.Error(\n          Parse.Error.OTHER_CAUSE,\n          'You cannot provide username/email and authData, only use one identification method.'\n        );\n      }\n\n      if (Object.keys(authData).filter(key => authData[key].id).length > 1) {\n        throw new Parse.Error(\n          Parse.Error.OTHER_CAUSE,\n          'You cannot provide more than one authData provider with an id.'\n        );\n      }\n\n      const results = await Auth.findUsersWithAuthData(req.config, authData);\n\n      try {\n        if (!results[0] || results.length > 1) {\n          throw new Parse.Error(Parse.Error.OBJECT_NOT_FOUND, 'User not found.');\n        }\n        // Find the provider used to find the user\n        const provider = Object.keys(authData).find(key => authData[key].id);\n\n        parseUser = Parse.User.fromJSON({ className: '_User', ...results[0] });\n        request = getRequestObject(undefined, req.auth, parseUser, parseUser, req.config);\n        request.isChallenge = true;\n        // Validate authData used to identify the user to avoid brute-force attack on `id`\n        const { validator } = req.config.authDataManager.getValidatorForProvider(provider);\n        const validatorResponse = await validator(authData[provider], req, parseUser, request);\n        if (validatorResponse && validatorResponse.validator) {\n          await validatorResponse.validator();\n        }\n      } catch (e) {\n        // Rewrite the error to avoid guess id attack\n        logger.error(e);\n        throw new Parse.Error(Parse.Error.OBJECT_NOT_FOUND, 'User not found.');\n      }\n    }\n\n    if (!parseUser) {\n      parseUser = user ? Parse.User.fromJSON({ className: '_User', ...user }) : undefined;\n    }\n\n    if (!request) {\n      request = getRequestObject(undefined, req.auth, parseUser, parseUser, req.config);\n      request.isChallenge = true;\n    }\n    const acc = {};\n    // Execute challenge step-by-step with consistent order for better error feedback\n    // and to avoid to trigger others challenges if one of them fails\n    for (const provider of Object.keys(challengeData).sort()) {\n      try {\n        const authAdapter = req.config.authDataManager.getValidatorForProvider(provider);\n        if (!authAdapter) {\n          continue;\n        }\n        const {\n          adapter: { challenge },\n        } = authAdapter;\n        if (typeof challenge === 'function') {\n          const providerChallengeResponse = await challenge(\n            challengeData[provider],\n            authData && authData[provider],\n            req.config.auth[provider],\n            request\n          );\n          acc[provider] = providerChallengeResponse || true;\n        }\n      } catch (err) {\n        const e = resolveError(err, {\n          code: Parse.Error.SCRIPT_FAILED,\n          message: 'Challenge failed. Unknown error.',\n        });\n        const userString = req.auth && req.auth.user ? req.auth.user.id : undefined;\n        logger.error(\n          `Failed running auth step challenge for ${provider} for user ${userString} with Error: ` +\n            JSON.stringify(e),\n          {\n            authenticationStep: 'challenge',\n            error: e,\n            user: userString,\n            provider,\n          }\n        );\n        throw e;\n      }\n    }\n    return { response: { challengeData: acc } };\n  }\n\n  mountRoutes() {\n    this.route('GET', '/users', req => {\n      return this.handleFind(req);\n    });\n    this.route('POST', '/users', promiseEnsureIdempotency, req => {\n      return this.handleCreate(req);\n    });\n    this.route('GET', '/users/me', req => {\n      return this.handleMe(req);\n    });\n    this.route('GET', '/users/:objectId', req => {\n      return this.handleGet(req);\n    });\n    this.route('PUT', '/users/:objectId', promiseEnsureIdempotency, req => {\n      return this.handleUpdate(req);\n    });\n    this.route('DELETE', '/users/:objectId', req => {\n      return this.handleDelete(req);\n    });\n    this.route('GET', '/login', req => {\n      return this.handleLogIn(req);\n    });\n    this.route('POST', '/login', req => {\n      return this.handleLogIn(req);\n    });\n    this.route('POST', '/loginAs', req => {\n      return this.handleLogInAs(req);\n    });\n    this.route('POST', '/logout', req => {\n      return this.handleLogOut(req);\n    });\n    this.route('POST', '/requestPasswordReset', req => {\n      return this.handleResetRequest(req);\n    });\n    this.route('POST', '/verificationEmailRequest', req => {\n      return this.handleVerificationEmailRequest(req);\n    });\n    this.route('GET', '/verifyPassword', req => {\n      return this.handleVerifyPassword(req);\n    });\n    this.route('POST', '/challenge', req => {\n      return this.handleChallenge(req);\n    });\n  }\n}\n\nexport default UsersRouter;\n"],"mappings":"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"}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "parse-server",
3
- "version": "7.0.0-alpha.4",
3
+ "version": "7.0.0-alpha.6",
4
4
  "description": "An express module providing a Parse-compatible API server",
5
5
  "main": "lib/index.js",
6
6
  "repository": {
@@ -33,7 +33,7 @@
33
33
  "deepcopy": "2.1.0",
34
34
  "express": "4.18.2",
35
35
  "express-rate-limit": "6.7.0",
36
- "follow-redirects": "1.15.2",
36
+ "follow-redirects": "1.15.4",
37
37
  "graphql": "16.8.1",
38
38
  "graphql-list-fields": "2.0.2",
39
39
  "graphql-relay": "0.10.0",