parse-server 8.0.0-alpha.12 → 8.0.0-alpha.13

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.
@@ -25,7 +25,6 @@ class PublicAPIRouter extends _PromiseRouter.default {
25
25
  }
26
26
  verifyEmail(req) {
27
27
  const {
28
- username,
29
28
  token: rawToken
30
29
  } = req.query;
31
30
  const token = rawToken && typeof rawToken !== 'string' ? rawToken.toString() : rawToken;
@@ -37,20 +36,17 @@ class PublicAPIRouter extends _PromiseRouter.default {
37
36
  if (!config.publicServerURL) {
38
37
  return this.missingPublicServerURL();
39
38
  }
40
- if (!token || !username) {
39
+ if (!token) {
41
40
  return this.invalidLink(req);
42
41
  }
43
42
  const userController = config.userController;
44
- return userController.verifyEmail(username, token).then(() => {
45
- const params = _querystring.default.stringify({
46
- username
47
- });
43
+ return userController.verifyEmail(token).then(() => {
48
44
  return Promise.resolve({
49
45
  status: 302,
50
- location: `${config.verifyEmailSuccessURL}?${params}`
46
+ location: `${config.verifyEmailSuccessURL}`
51
47
  });
52
48
  }, () => {
53
- return this.invalidVerificationLink(req);
49
+ return this.invalidVerificationLink(req, token);
54
50
  });
55
51
  }
56
52
  resendVerificationEmail(req) {
@@ -63,11 +59,12 @@ class PublicAPIRouter extends _PromiseRouter.default {
63
59
  if (!config.publicServerURL) {
64
60
  return this.missingPublicServerURL();
65
61
  }
66
- if (!username) {
62
+ const token = req.body.token;
63
+ if (!username && !token) {
67
64
  return this.invalidLink(req);
68
65
  }
69
66
  const userController = config.userController;
70
- return userController.resendVerificationEmail(username, req).then(() => {
67
+ return userController.resendVerificationEmail(username, req, token).then(() => {
71
68
  return Promise.resolve({
72
69
  status: 302,
73
70
  location: `${config.linkSendSuccessURL}`
@@ -112,18 +109,16 @@ class PublicAPIRouter extends _PromiseRouter.default {
112
109
  return this.missingPublicServerURL();
113
110
  }
114
111
  const {
115
- username,
116
112
  token: rawToken
117
113
  } = req.query;
118
114
  const token = rawToken && typeof rawToken !== 'string' ? rawToken.toString() : rawToken;
119
- if (!username || !token) {
115
+ if (!token) {
120
116
  return this.invalidLink(req);
121
117
  }
122
- return config.userController.checkResetTokenValidity(username, token).then(() => {
118
+ return config.userController.checkResetTokenValidity(token).then(() => {
123
119
  const params = _querystring.default.stringify({
124
120
  token,
125
121
  id: config.applicationId,
126
- username,
127
122
  app: config.appName
128
123
  });
129
124
  return Promise.resolve({
@@ -143,24 +138,20 @@ class PublicAPIRouter extends _PromiseRouter.default {
143
138
  return this.missingPublicServerURL();
144
139
  }
145
140
  const {
146
- username,
147
141
  new_password,
148
142
  token: rawToken
149
143
  } = req.body;
150
144
  const token = rawToken && typeof rawToken !== 'string' ? rawToken.toString() : rawToken;
151
- if ((!username || !token || !new_password) && req.xhr === false) {
145
+ if ((!token || !new_password) && req.xhr === false) {
152
146
  return this.invalidLink(req);
153
147
  }
154
- if (!username) {
155
- throw new _node.Parse.Error(_node.Parse.Error.USERNAME_MISSING, 'Missing username');
156
- }
157
148
  if (!token) {
158
149
  throw new _node.Parse.Error(_node.Parse.Error.OTHER_CAUSE, 'Missing token');
159
150
  }
160
151
  if (!new_password) {
161
152
  throw new _node.Parse.Error(_node.Parse.Error.PASSWORD_MISSING, 'Missing password');
162
153
  }
163
- return config.userController.updatePassword(username, token, new_password).then(() => {
154
+ return config.userController.updatePassword(token, new_password).then(() => {
164
155
  return Promise.resolve({
165
156
  success: true
166
157
  });
@@ -170,13 +161,17 @@ class PublicAPIRouter extends _PromiseRouter.default {
170
161
  err
171
162
  });
172
163
  }).then(result => {
173
- const params = _querystring.default.stringify({
174
- username: username,
164
+ const queryString = {
175
165
  token: token,
176
166
  id: config.applicationId,
177
167
  error: result.err,
178
168
  app: config.appName
179
- });
169
+ };
170
+ if (result?.err === 'The password reset link has expired') {
171
+ delete queryString.token;
172
+ queryString.token = token;
173
+ }
174
+ const params = _querystring.default.stringify(queryString);
180
175
  if (req.xhr) {
181
176
  if (result.success) {
182
177
  return Promise.resolve({
@@ -188,8 +183,7 @@ class PublicAPIRouter extends _PromiseRouter.default {
188
183
  throw new _node.Parse.Error(_node.Parse.Error.OTHER_CAUSE, `${result.err}`);
189
184
  }
190
185
  }
191
- const encodedUsername = encodeURIComponent(username);
192
- const location = result.success ? `${config.passwordResetSuccessURL}?username=${encodedUsername}` : `${config.choosePasswordURL}?${params}`;
186
+ const location = result.success ? `${config.passwordResetSuccessURL}` : `${config.choosePasswordURL}?${params}`;
193
187
  return Promise.resolve({
194
188
  status: 302,
195
189
  location
@@ -202,12 +196,12 @@ class PublicAPIRouter extends _PromiseRouter.default {
202
196
  location: req.config.invalidLinkURL
203
197
  });
204
198
  }
205
- invalidVerificationLink(req) {
199
+ invalidVerificationLink(req, token) {
206
200
  const config = req.config;
207
- if (req.query.username && req.params.appId) {
201
+ if (req.params.appId) {
208
202
  const params = _querystring.default.stringify({
209
- username: req.query.username,
210
- appId: req.params.appId
203
+ appId: req.params.appId,
204
+ token
211
205
  });
212
206
  return Promise.resolve({
213
207
  status: 302,
@@ -267,4 +261,4 @@ class PublicAPIRouter extends _PromiseRouter.default {
267
261
  }
268
262
  exports.PublicAPIRouter = PublicAPIRouter;
269
263
  var _default = exports.default = PublicAPIRouter;
270
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_PromiseRouter","_interopRequireDefault","require","_Config","_express","_path","_fs","_querystring","_node","_Deprecator","e","__esModule","default","public_html","path","resolve","__dirname","views","PublicAPIRouter","PromiseRouter","constructor","Deprecator","logRuntimeDeprecation","usage","solution","verifyEmail","req","username","token","rawToken","query","toString","appId","params","config","Config","get","invalidRequest","publicServerURL","missingPublicServerURL","invalidLink","userController","then","qs","stringify","Promise","status","location","verifyEmailSuccessURL","invalidVerificationLink","resendVerificationEmail","body","linkSendSuccessURL","linkSendFailURL","changePassword","reject","id","text","fs","readFile","err","data","replace","requestResetPassword","checkResetTokenValidity","applicationId","app","appName","choosePasswordURL","resetPassword","new_password","xhr","Parse","Error","USERNAME_MISSING","OTHER_CAUSE","PASSWORD_MISSING","updatePassword","success","result","error","response","encodedUsername","encodeURIComponent","passwordResetSuccessURL","invalidLinkURL","invalidVerificationLinkURL","message","setConfig","mountRoutes","route","expressRouter","router","express","Router","use","static","exports","_default"],"sources":["../../src/Routers/PublicAPIRouter.js"],"sourcesContent":["import PromiseRouter from '../PromiseRouter';\nimport Config from '../Config';\nimport express from 'express';\nimport path from 'path';\nimport fs from 'fs';\nimport qs from 'querystring';\nimport { Parse } from 'parse/node';\nimport Deprecator from '../Deprecator/Deprecator';\n\nconst public_html = path.resolve(__dirname, '../../public_html');\nconst views = path.resolve(__dirname, '../../views');\n\nexport class PublicAPIRouter extends PromiseRouter {\n  constructor() {\n    super();\n    Deprecator.logRuntimeDeprecation({\n      usage: 'PublicAPIRouter',\n      solution: 'pages.enableRouter'\n    });\n  }\n  verifyEmail(req) {\n    const { username, token: rawToken } = req.query;\n    const token = rawToken && typeof rawToken !== 'string' ? rawToken.toString() : rawToken;\n\n    const appId = req.params.appId;\n    const config = Config.get(appId);\n\n    if (!config) {\n      this.invalidRequest();\n    }\n\n    if (!config.publicServerURL) {\n      return this.missingPublicServerURL();\n    }\n\n    if (!token || !username) {\n      return this.invalidLink(req);\n    }\n\n    const userController = config.userController;\n    return userController.verifyEmail(username, token).then(\n      () => {\n        const params = qs.stringify({ username });\n        return Promise.resolve({\n          status: 302,\n          location: `${config.verifyEmailSuccessURL}?${params}`,\n        });\n      },\n      () => {\n        return this.invalidVerificationLink(req);\n      }\n    );\n  }\n\n  resendVerificationEmail(req) {\n    const username = req.body.username;\n    const appId = req.params.appId;\n    const config = Config.get(appId);\n\n    if (!config) {\n      this.invalidRequest();\n    }\n\n    if (!config.publicServerURL) {\n      return this.missingPublicServerURL();\n    }\n\n    if (!username) {\n      return this.invalidLink(req);\n    }\n\n    const userController = config.userController;\n\n    return userController.resendVerificationEmail(username, req).then(\n      () => {\n        return Promise.resolve({\n          status: 302,\n          location: `${config.linkSendSuccessURL}`,\n        });\n      },\n      () => {\n        return Promise.resolve({\n          status: 302,\n          location: `${config.linkSendFailURL}`,\n        });\n      }\n    );\n  }\n\n  changePassword(req) {\n    return new Promise((resolve, reject) => {\n      const config = Config.get(req.query.id);\n\n      if (!config) {\n        this.invalidRequest();\n      }\n\n      if (!config.publicServerURL) {\n        return resolve({\n          status: 404,\n          text: 'Not found.',\n        });\n      }\n      // Should we keep the file in memory or leave like that?\n      fs.readFile(path.resolve(views, 'choose_password'), 'utf-8', (err, data) => {\n        if (err) {\n          return reject(err);\n        }\n        data = data.replace('PARSE_SERVER_URL', `'${config.publicServerURL}'`);\n        resolve({\n          text: data,\n        });\n      });\n    });\n  }\n\n  requestResetPassword(req) {\n    const config = req.config;\n\n    if (!config) {\n      this.invalidRequest();\n    }\n\n    if (!config.publicServerURL) {\n      return this.missingPublicServerURL();\n    }\n\n    const { username, token: rawToken } = req.query;\n    const token = rawToken && typeof rawToken !== 'string' ? rawToken.toString() : rawToken;\n\n    if (!username || !token) {\n      return this.invalidLink(req);\n    }\n\n    return config.userController.checkResetTokenValidity(username, token).then(\n      () => {\n        const params = qs.stringify({\n          token,\n          id: config.applicationId,\n          username,\n          app: config.appName,\n        });\n        return Promise.resolve({\n          status: 302,\n          location: `${config.choosePasswordURL}?${params}`,\n        });\n      },\n      () => {\n        return this.invalidLink(req);\n      }\n    );\n  }\n\n  resetPassword(req) {\n    const config = req.config;\n\n    if (!config) {\n      this.invalidRequest();\n    }\n\n    if (!config.publicServerURL) {\n      return this.missingPublicServerURL();\n    }\n\n    const { username, new_password, token: rawToken } = req.body;\n    const token = rawToken && typeof rawToken !== 'string' ? rawToken.toString() : rawToken;\n\n    if ((!username || !token || !new_password) && req.xhr === false) {\n      return this.invalidLink(req);\n    }\n\n    if (!username) {\n      throw new Parse.Error(Parse.Error.USERNAME_MISSING, 'Missing username');\n    }\n\n    if (!token) {\n      throw new Parse.Error(Parse.Error.OTHER_CAUSE, 'Missing token');\n    }\n\n    if (!new_password) {\n      throw new Parse.Error(Parse.Error.PASSWORD_MISSING, 'Missing password');\n    }\n\n    return config.userController\n      .updatePassword(username, token, new_password)\n      .then(\n        () => {\n          return Promise.resolve({\n            success: true,\n          });\n        },\n        err => {\n          return Promise.resolve({\n            success: false,\n            err,\n          });\n        }\n      )\n      .then(result => {\n        const params = qs.stringify({\n          username: username,\n          token: token,\n          id: config.applicationId,\n          error: result.err,\n          app: config.appName,\n        });\n\n        if (req.xhr) {\n          if (result.success) {\n            return Promise.resolve({\n              status: 200,\n              response: 'Password successfully reset',\n            });\n          }\n          if (result.err) {\n            throw new Parse.Error(Parse.Error.OTHER_CAUSE, `${result.err}`);\n          }\n        }\n\n        const encodedUsername = encodeURIComponent(username);\n        const location = result.success\n          ? `${config.passwordResetSuccessURL}?username=${encodedUsername}`\n          : `${config.choosePasswordURL}?${params}`;\n\n        return Promise.resolve({\n          status: 302,\n          location,\n        });\n      });\n  }\n\n  invalidLink(req) {\n    return Promise.resolve({\n      status: 302,\n      location: req.config.invalidLinkURL,\n    });\n  }\n\n  invalidVerificationLink(req) {\n    const config = req.config;\n    if (req.query.username && req.params.appId) {\n      const params = qs.stringify({\n        username: req.query.username,\n        appId: req.params.appId,\n      });\n      return Promise.resolve({\n        status: 302,\n        location: `${config.invalidVerificationLinkURL}?${params}`,\n      });\n    } else {\n      return this.invalidLink(req);\n    }\n  }\n\n  missingPublicServerURL() {\n    return Promise.resolve({\n      text: 'Not found.',\n      status: 404,\n    });\n  }\n\n  invalidRequest() {\n    const error = new Error();\n    error.status = 403;\n    error.message = 'unauthorized';\n    throw error;\n  }\n\n  setConfig(req) {\n    req.config = Config.get(req.params.appId);\n    return Promise.resolve();\n  }\n\n  mountRoutes() {\n    this.route(\n      'GET',\n      '/apps/:appId/verify_email',\n      req => {\n        this.setConfig(req);\n      },\n      req => {\n        return this.verifyEmail(req);\n      }\n    );\n\n    this.route(\n      'POST',\n      '/apps/:appId/resend_verification_email',\n      req => {\n        this.setConfig(req);\n      },\n      req => {\n        return this.resendVerificationEmail(req);\n      }\n    );\n\n    this.route('GET', '/apps/choose_password', req => {\n      return this.changePassword(req);\n    });\n\n    this.route(\n      'POST',\n      '/apps/:appId/request_password_reset',\n      req => {\n        this.setConfig(req);\n      },\n      req => {\n        return this.resetPassword(req);\n      }\n    );\n\n    this.route(\n      'GET',\n      '/apps/:appId/request_password_reset',\n      req => {\n        this.setConfig(req);\n      },\n      req => {\n        return this.requestResetPassword(req);\n      }\n    );\n  }\n\n  expressRouter() {\n    const router = express.Router();\n    router.use('/apps', express.static(public_html));\n    router.use('/', super.expressRouter());\n    return router;\n  }\n}\n\nexport default PublicAPIRouter;\n"],"mappings":"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","ignoreList":[]}
264
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_PromiseRouter","_interopRequireDefault","require","_Config","_express","_path","_fs","_querystring","_node","_Deprecator","e","__esModule","default","public_html","path","resolve","__dirname","views","PublicAPIRouter","PromiseRouter","constructor","Deprecator","logRuntimeDeprecation","usage","solution","verifyEmail","req","token","rawToken","query","toString","appId","params","config","Config","get","invalidRequest","publicServerURL","missingPublicServerURL","invalidLink","userController","then","Promise","status","location","verifyEmailSuccessURL","invalidVerificationLink","resendVerificationEmail","username","body","linkSendSuccessURL","linkSendFailURL","changePassword","reject","id","text","fs","readFile","err","data","replace","requestResetPassword","checkResetTokenValidity","qs","stringify","applicationId","app","appName","choosePasswordURL","resetPassword","new_password","xhr","Parse","Error","OTHER_CAUSE","PASSWORD_MISSING","updatePassword","success","result","queryString","error","response","passwordResetSuccessURL","invalidLinkURL","invalidVerificationLinkURL","message","setConfig","mountRoutes","route","expressRouter","router","express","Router","use","static","exports","_default"],"sources":["../../src/Routers/PublicAPIRouter.js"],"sourcesContent":["import PromiseRouter from '../PromiseRouter';\nimport Config from '../Config';\nimport express from 'express';\nimport path from 'path';\nimport fs from 'fs';\nimport qs from 'querystring';\nimport { Parse } from 'parse/node';\nimport Deprecator from '../Deprecator/Deprecator';\n\nconst public_html = path.resolve(__dirname, '../../public_html');\nconst views = path.resolve(__dirname, '../../views');\n\nexport class PublicAPIRouter extends PromiseRouter {\n  constructor() {\n    super();\n    Deprecator.logRuntimeDeprecation({\n      usage: 'PublicAPIRouter',\n      solution: 'pages.enableRouter'\n    });\n  }\n  verifyEmail(req) {\n    const { token: rawToken } = req.query;\n    const token = rawToken && typeof rawToken !== 'string' ? rawToken.toString() : rawToken;\n\n    const appId = req.params.appId;\n    const config = Config.get(appId);\n\n    if (!config) {\n      this.invalidRequest();\n    }\n\n    if (!config.publicServerURL) {\n      return this.missingPublicServerURL();\n    }\n\n    if (!token) {\n      return this.invalidLink(req);\n    }\n\n    const userController = config.userController;\n    return userController.verifyEmail(token).then(\n      () => {\n        return Promise.resolve({\n          status: 302,\n          location: `${config.verifyEmailSuccessURL}`,\n        });\n      },\n      () => {\n        return this.invalidVerificationLink(req, token);\n      }\n    );\n  }\n\n  resendVerificationEmail(req) {\n    const username = req.body.username;\n    const appId = req.params.appId;\n    const config = Config.get(appId);\n\n    if (!config) {\n      this.invalidRequest();\n    }\n\n    if (!config.publicServerURL) {\n      return this.missingPublicServerURL();\n    }\n\n    const token = req.body.token;\n\n    if (!username && !token) {\n      return this.invalidLink(req);\n    }\n\n    const userController = config.userController;\n\n    return userController.resendVerificationEmail(username, req, token).then(\n      () => {\n        return Promise.resolve({\n          status: 302,\n          location: `${config.linkSendSuccessURL}`,\n        });\n      },\n      () => {\n        return Promise.resolve({\n          status: 302,\n          location: `${config.linkSendFailURL}`,\n        });\n      }\n    );\n  }\n\n  changePassword(req) {\n    return new Promise((resolve, reject) => {\n      const config = Config.get(req.query.id);\n\n      if (!config) {\n        this.invalidRequest();\n      }\n\n      if (!config.publicServerURL) {\n        return resolve({\n          status: 404,\n          text: 'Not found.',\n        });\n      }\n      // Should we keep the file in memory or leave like that?\n      fs.readFile(path.resolve(views, 'choose_password'), 'utf-8', (err, data) => {\n        if (err) {\n          return reject(err);\n        }\n        data = data.replace('PARSE_SERVER_URL', `'${config.publicServerURL}'`);\n        resolve({\n          text: data,\n        });\n      });\n    });\n  }\n\n  requestResetPassword(req) {\n    const config = req.config;\n\n    if (!config) {\n      this.invalidRequest();\n    }\n\n    if (!config.publicServerURL) {\n      return this.missingPublicServerURL();\n    }\n\n    const { token: rawToken } = req.query;\n    const token = rawToken && typeof rawToken !== 'string' ? rawToken.toString() : rawToken;\n\n    if (!token) {\n      return this.invalidLink(req);\n    }\n\n    return config.userController.checkResetTokenValidity(token).then(\n      () => {\n        const params = qs.stringify({\n          token,\n          id: config.applicationId,\n          app: config.appName,\n        });\n        return Promise.resolve({\n          status: 302,\n          location: `${config.choosePasswordURL}?${params}`,\n        });\n      },\n      () => {\n        return this.invalidLink(req);\n      }\n    );\n  }\n\n  resetPassword(req) {\n    const config = req.config;\n\n    if (!config) {\n      this.invalidRequest();\n    }\n\n    if (!config.publicServerURL) {\n      return this.missingPublicServerURL();\n    }\n\n    const { new_password, token: rawToken } = req.body;\n    const token = rawToken && typeof rawToken !== 'string' ? rawToken.toString() : rawToken;\n\n    if ((!token || !new_password) && req.xhr === false) {\n      return this.invalidLink(req);\n    }\n\n    if (!token) {\n      throw new Parse.Error(Parse.Error.OTHER_CAUSE, 'Missing token');\n    }\n\n    if (!new_password) {\n      throw new Parse.Error(Parse.Error.PASSWORD_MISSING, 'Missing password');\n    }\n\n    return config.userController\n      .updatePassword(token, new_password)\n      .then(\n        () => {\n          return Promise.resolve({\n            success: true,\n          });\n        },\n        err => {\n          return Promise.resolve({\n            success: false,\n            err,\n          });\n        }\n      )\n      .then(result => {\n        const queryString = {\n          token: token,\n          id: config.applicationId,\n          error: result.err,\n          app: config.appName,\n        };\n\n        if (result?.err === 'The password reset link has expired') {\n          delete queryString.token;\n          queryString.token = token;\n        }\n        const params = qs.stringify(queryString);\n\n        if (req.xhr) {\n          if (result.success) {\n            return Promise.resolve({\n              status: 200,\n              response: 'Password successfully reset',\n            });\n          }\n          if (result.err) {\n            throw new Parse.Error(Parse.Error.OTHER_CAUSE, `${result.err}`);\n          }\n        }\n\n        const location = result.success\n          ? `${config.passwordResetSuccessURL}`\n          : `${config.choosePasswordURL}?${params}`;\n\n        return Promise.resolve({\n          status: 302,\n          location,\n        });\n      });\n  }\n\n  invalidLink(req) {\n    return Promise.resolve({\n      status: 302,\n      location: req.config.invalidLinkURL,\n    });\n  }\n\n  invalidVerificationLink(req, token) {\n    const config = req.config;\n    if (req.params.appId) {\n      const params = qs.stringify({\n        appId: req.params.appId,\n        token,\n      });\n      return Promise.resolve({\n        status: 302,\n        location: `${config.invalidVerificationLinkURL}?${params}`,\n      });\n    } else {\n      return this.invalidLink(req);\n    }\n  }\n\n  missingPublicServerURL() {\n    return Promise.resolve({\n      text: 'Not found.',\n      status: 404,\n    });\n  }\n\n  invalidRequest() {\n    const error = new Error();\n    error.status = 403;\n    error.message = 'unauthorized';\n    throw error;\n  }\n\n  setConfig(req) {\n    req.config = Config.get(req.params.appId);\n    return Promise.resolve();\n  }\n\n  mountRoutes() {\n    this.route(\n      'GET',\n      '/apps/:appId/verify_email',\n      req => {\n        this.setConfig(req);\n      },\n      req => {\n        return this.verifyEmail(req);\n      }\n    );\n\n    this.route(\n      'POST',\n      '/apps/:appId/resend_verification_email',\n      req => {\n        this.setConfig(req);\n      },\n      req => {\n        return this.resendVerificationEmail(req);\n      }\n    );\n\n    this.route('GET', '/apps/choose_password', req => {\n      return this.changePassword(req);\n    });\n\n    this.route(\n      'POST',\n      '/apps/:appId/request_password_reset',\n      req => {\n        this.setConfig(req);\n      },\n      req => {\n        return this.resetPassword(req);\n      }\n    );\n\n    this.route(\n      'GET',\n      '/apps/:appId/request_password_reset',\n      req => {\n        this.setConfig(req);\n      },\n      req => {\n        return this.requestResetPassword(req);\n      }\n    );\n  }\n\n  expressRouter() {\n    const router = express.Router();\n    router.use('/apps', express.static(public_html));\n    router.use('/', super.expressRouter());\n    return router;\n  }\n}\n\nexport default PublicAPIRouter;\n"],"mappings":"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","ignoreList":[]}
@@ -374,12 +374,22 @@ class UsersRouter extends _ClassesRouter.default {
374
374
  }
375
375
  async handleResetRequest(req) {
376
376
  this._throwOnBadEmailConfig(req);
377
- const {
378
- email
379
- } = req.body;
380
- if (!email) {
377
+ let email = req.body.email;
378
+ const token = req.body.token;
379
+ if (!email && !token) {
381
380
  throw new _node.default.Error(_node.default.Error.EMAIL_MISSING, 'you must provide an email');
382
381
  }
382
+ if (token) {
383
+ const results = await req.config.database.find('_User', {
384
+ _perishable_token: token,
385
+ _perishable_token_expires_at: {
386
+ $lt: _node.default._encode(new Date())
387
+ }
388
+ });
389
+ if (results && results[0] && results[0].email) {
390
+ email = results[0].email;
391
+ }
392
+ }
383
393
  if (typeof email !== 'string') {
384
394
  throw new _node.default.Error(_node.default.Error.INVALID_EMAIL_ADDRESS, 'you must provide a valid email string');
385
395
  }
@@ -597,4 +607,4 @@ class UsersRouter extends _ClassesRouter.default {
597
607
  }
598
608
  exports.UsersRouter = UsersRouter;
599
609
  var _default = exports.default = UsersRouter;
600
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_node","_interopRequireDefault","require","_Config","_AccountLockout","_ClassesRouter","_rest","_Auth","_password","_triggers","_middlewares","_RestWrite","_logger","e","__esModule","default","UsersRouter","ClassesRouter","className","removeHiddenProperties","obj","key","Object","prototype","hasOwnProperty","call","test","_sanitizeAuthData","user","password","authData","keys","forEach","provider","length","_authenticateUserFromRequest","req","Promise","resolve","reject","payload","body","username","query","email","ignoreEmailVerification","Parse","Error","USERNAME_MISSING","PASSWORD_MISSING","OBJECT_NOT_FOUND","isValidPassword","$or","config","database","find","Auth","maintenance","then","results","loggerController","warn","filter","passwordCrypto","compare","correct","accountLockoutPolicy","AccountLockout","handleLoginAttempt","auth","isMaster","ACL","request","master","ip","installationId","object","User","fromJSON","assign","isMaintenance","verifyUserEmails","preventLoginWithUnverifiedEmail","emailVerified","EMAIL_NOT_FOUND","catch","error","handleMe","info","sessionToken","INVALID_SESSION_TOKEN","rest","include","clientSDK","context","response","handleLogIn","checkIfUserHasProvidedConfiguredProvidersForLogin","authDataResponse","validatedAuthData","res","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","undefined","del","afterLogout","Session","_throwOnBadEmailConfig","Config","validateEmailConfiguration","emailAdapter","userController","adapter","appName","publicServerURL","emailVerifyTokenValidityDuration","emailVerifyTokenReuseIfValid","INTERNAL_SERVER_ERROR","handleResetRequest","EMAIL_MISSING","INVALID_EMAIL_ADDRESS","sendPasswordResetEmail","err","code","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, ignoreEmailVerification } = 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\n          // If request doesn't use master or maintenance key with ignoring email verification\n          if (!((req.auth.isMaster || req.auth.isMaintenance) && ignoreEmailVerification)) {\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\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    await 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', '/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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","ignoreList":[]}
610
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_node","_interopRequireDefault","require","_Config","_AccountLockout","_ClassesRouter","_rest","_Auth","_password","_triggers","_middlewares","_RestWrite","_logger","e","__esModule","default","UsersRouter","ClassesRouter","className","removeHiddenProperties","obj","key","Object","prototype","hasOwnProperty","call","test","_sanitizeAuthData","user","password","authData","keys","forEach","provider","length","_authenticateUserFromRequest","req","Promise","resolve","reject","payload","body","username","query","email","ignoreEmailVerification","Parse","Error","USERNAME_MISSING","PASSWORD_MISSING","OBJECT_NOT_FOUND","isValidPassword","$or","config","database","find","Auth","maintenance","then","results","loggerController","warn","filter","passwordCrypto","compare","correct","accountLockoutPolicy","AccountLockout","handleLoginAttempt","auth","isMaster","ACL","request","master","ip","installationId","object","User","fromJSON","assign","isMaintenance","verifyUserEmails","preventLoginWithUnverifiedEmail","emailVerified","EMAIL_NOT_FOUND","catch","error","handleMe","info","sessionToken","INVALID_SESSION_TOKEN","rest","include","clientSDK","context","response","handleLogIn","checkIfUserHasProvidedConfiguredProvidersForLogin","authDataResponse","validatedAuthData","res","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","undefined","del","afterLogout","Session","_throwOnBadEmailConfig","Config","validateEmailConfiguration","emailAdapter","userController","adapter","appName","publicServerURL","emailVerifyTokenValidityDuration","emailVerifyTokenReuseIfValid","INTERNAL_SERVER_ERROR","handleResetRequest","token","EMAIL_MISSING","_perishable_token","_perishable_token_expires_at","$lt","INVALID_EMAIL_ADDRESS","sendPasswordResetEmail","err","code","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, ignoreEmailVerification } = 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\n          // If request doesn't use master or maintenance key with ignoring email verification\n          if (!((req.auth.isMaster || req.auth.isMaintenance) && ignoreEmailVerification)) {\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\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    await 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    let email = req.body.email;\n    const token = req.body.token;\n    if (!email && !token) {\n      throw new Parse.Error(Parse.Error.EMAIL_MISSING, 'you must provide an email');\n    }\n    if (token) {\n      const results = await req.config.database.find('_User', {\n        _perishable_token: token,\n        _perishable_token_expires_at: { $lt: Parse._encode(new Date()) },\n      });\n      if (results && results[0] && results[0].email) {\n        email = results[0].email;\n      }\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', '/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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","ignoreList":[]}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "parse-server",
3
- "version": "8.0.0-alpha.12",
3
+ "version": "8.0.0-alpha.13",
4
4
  "description": "An express module providing a Parse-compatible API server",
5
5
  "main": "lib/index.js",
6
6
  "repository": {
@@ -47,8 +47,8 @@
47
47
  window.onload = addDataToForm;
48
48
 
49
49
  function addDataToForm() {
50
- var username = getUrlParameter("username");
51
- document.getElementById("usernameField").value = username;
50
+ const token = getUrlParameter("token");
51
+ document.getElementById("token").value = token;
52
52
 
53
53
  var appId = getUrlParameter("appId");
54
54
  document.getElementById("resendForm").action = '/apps/' + appId + '/resend_verification_email'
@@ -60,7 +60,7 @@
60
60
  <div class="container">
61
61
  <h1>Invalid Verification Link</h1>
62
62
  <form id="resendForm" method="POST" action="/resend_verification_email">
63
- <input id="usernameField" class="form-control" name="username" type="hidden" value="">
63
+ <input id="token" class="form-control" name="token" type="hidden" value="">
64
64
  <button type="submit" class="btn btn-default">Resend Link</button>
65
65
  </form>
66
66
  </div>