parse-server 8.0.0-alpha.12 → 8.0.0-alpha.14
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/lib/Controllers/UserController.js +43 -48
- package/lib/GraphQL/loaders/usersMutations.js +2 -6
- package/lib/Routers/PagesRouter.js +18 -32
- package/lib/Routers/PublicAPIRouter.js +24 -30
- package/lib/Routers/UsersRouter.js +15 -5
- package/package.json +2 -2
- package/public_html/invalid_verification_link.html +3 -3
|
@@ -50,14 +50,13 @@ class UserController extends _AdaptableController.default {
|
|
|
50
50
|
}
|
|
51
51
|
return true;
|
|
52
52
|
}
|
|
53
|
-
async verifyEmail(
|
|
53
|
+
async verifyEmail(token) {
|
|
54
54
|
if (!this.shouldVerifyEmails) {
|
|
55
55
|
// Trying to verify email when not enabled
|
|
56
56
|
// TODO: Better error here.
|
|
57
57
|
throw undefined;
|
|
58
58
|
}
|
|
59
59
|
const query = {
|
|
60
|
-
username: username,
|
|
61
60
|
_email_verify_token: token
|
|
62
61
|
};
|
|
63
62
|
const updateFields = {
|
|
@@ -79,45 +78,38 @@ class UserController extends _AdaptableController.default {
|
|
|
79
78
|
};
|
|
80
79
|
}
|
|
81
80
|
const maintenanceAuth = Auth.maintenance(this.config);
|
|
82
|
-
|
|
81
|
+
const restQuery = await RestQuery({
|
|
83
82
|
method: RestQuery.Method.get,
|
|
84
83
|
config: this.config,
|
|
85
84
|
auth: maintenanceAuth,
|
|
86
85
|
className: '_User',
|
|
87
|
-
restWhere:
|
|
88
|
-
username
|
|
89
|
-
}
|
|
90
|
-
});
|
|
91
|
-
return findUserForEmailVerification.execute().then(result => {
|
|
92
|
-
if (result.results.length && result.results[0].emailVerified) {
|
|
93
|
-
return Promise.resolve(result.results.length[0]);
|
|
94
|
-
} else if (result.results.length) {
|
|
95
|
-
query.objectId = result.results[0].objectId;
|
|
96
|
-
}
|
|
97
|
-
return _rest.default.update(this.config, maintenanceAuth, '_User', query, updateFields);
|
|
86
|
+
restWhere: query
|
|
98
87
|
});
|
|
88
|
+
const result = await restQuery.execute();
|
|
89
|
+
if (result.results.length) {
|
|
90
|
+
query.objectId = result.results[0].objectId;
|
|
91
|
+
}
|
|
92
|
+
return await _rest.default.update(this.config, maintenanceAuth, '_User', query, updateFields);
|
|
99
93
|
}
|
|
100
|
-
checkResetTokenValidity(
|
|
101
|
-
|
|
102
|
-
username: username,
|
|
94
|
+
async checkResetTokenValidity(token) {
|
|
95
|
+
const results = await this.config.database.find('_User', {
|
|
103
96
|
_perishable_token: token
|
|
104
97
|
}, {
|
|
105
98
|
limit: 1
|
|
106
|
-
}, Auth.maintenance(this.config))
|
|
107
|
-
|
|
108
|
-
|
|
99
|
+
}, Auth.maintenance(this.config));
|
|
100
|
+
if (results.length !== 1) {
|
|
101
|
+
throw 'Failed to reset password: username / email / token is invalid';
|
|
102
|
+
}
|
|
103
|
+
if (this.config.passwordPolicy && this.config.passwordPolicy.resetTokenValidityDuration) {
|
|
104
|
+
let expiresDate = results[0]._perishable_token_expires_at;
|
|
105
|
+
if (expiresDate && expiresDate.__type == 'Date') {
|
|
106
|
+
expiresDate = new Date(expiresDate.iso);
|
|
109
107
|
}
|
|
110
|
-
if (
|
|
111
|
-
|
|
112
|
-
if (expiresDate && expiresDate.__type == 'Date') {
|
|
113
|
-
expiresDate = new Date(expiresDate.iso);
|
|
114
|
-
}
|
|
115
|
-
if (expiresDate < new Date()) {
|
|
116
|
-
throw 'The password reset link has expired';
|
|
117
|
-
}
|
|
108
|
+
if (expiresDate < new Date()) {
|
|
109
|
+
throw 'The password reset link has expired';
|
|
118
110
|
}
|
|
119
|
-
|
|
120
|
-
|
|
111
|
+
}
|
|
112
|
+
return results[0];
|
|
121
113
|
}
|
|
122
114
|
async getUserIfNeeded(user) {
|
|
123
115
|
var where = {};
|
|
@@ -127,6 +119,9 @@ class UserController extends _AdaptableController.default {
|
|
|
127
119
|
if (user.email) {
|
|
128
120
|
where.email = user.email;
|
|
129
121
|
}
|
|
122
|
+
if (user._email_verify_token) {
|
|
123
|
+
where._email_verify_token = user._email_verify_token;
|
|
124
|
+
}
|
|
130
125
|
var query = await RestQuery({
|
|
131
126
|
method: RestQuery.Method.get,
|
|
132
127
|
config: this.config,
|
|
@@ -163,8 +158,7 @@ class UserController extends _AdaptableController.default {
|
|
|
163
158
|
if (!shouldSendEmail) {
|
|
164
159
|
return;
|
|
165
160
|
}
|
|
166
|
-
const
|
|
167
|
-
const link = buildEmailLink(this.config.verifyEmailURL, username, token, this.config);
|
|
161
|
+
const link = buildEmailLink(this.config.verifyEmailURL, token, this.config);
|
|
168
162
|
const options = {
|
|
169
163
|
appName: this.config.appName,
|
|
170
164
|
link: link,
|
|
@@ -212,9 +206,10 @@ class UserController extends _AdaptableController.default {
|
|
|
212
206
|
username: user.username
|
|
213
207
|
}, user);
|
|
214
208
|
}
|
|
215
|
-
async resendVerificationEmail(username, req) {
|
|
209
|
+
async resendVerificationEmail(username, req, token) {
|
|
216
210
|
const aUser = await this.getUserIfNeeded({
|
|
217
|
-
username
|
|
211
|
+
username,
|
|
212
|
+
_email_verify_token: token
|
|
218
213
|
});
|
|
219
214
|
if (!aUser || aUser.emailVerified) {
|
|
220
215
|
throw undefined;
|
|
@@ -281,8 +276,7 @@ class UserController extends _AdaptableController.default {
|
|
|
281
276
|
user = await this.setPasswordResetToken(email);
|
|
282
277
|
}
|
|
283
278
|
const token = encodeURIComponent(user._perishable_token);
|
|
284
|
-
const
|
|
285
|
-
const link = buildEmailLink(this.config.requestResetPasswordURL, username, token, this.config);
|
|
279
|
+
const link = buildEmailLink(this.config.requestResetPasswordURL, token, this.config);
|
|
286
280
|
const options = {
|
|
287
281
|
appName: this.config.appName,
|
|
288
282
|
link: link,
|
|
@@ -295,18 +289,19 @@ class UserController extends _AdaptableController.default {
|
|
|
295
289
|
}
|
|
296
290
|
return Promise.resolve(user);
|
|
297
291
|
}
|
|
298
|
-
updatePassword(
|
|
299
|
-
|
|
292
|
+
async updatePassword(token, password) {
|
|
293
|
+
try {
|
|
294
|
+
const rawUser = await this.checkResetTokenValidity(token);
|
|
295
|
+
const user = await updateUserPassword(rawUser, password, this.config);
|
|
300
296
|
const accountLockoutPolicy = new _AccountLockout.default(user, this.config);
|
|
301
|
-
return accountLockoutPolicy.unlockAccount();
|
|
302
|
-
}
|
|
297
|
+
return await accountLockoutPolicy.unlockAccount();
|
|
298
|
+
} catch (error) {
|
|
303
299
|
if (error && error.message) {
|
|
304
300
|
// in case of Parse.Error, fail with the error message only
|
|
305
301
|
return Promise.reject(error.message);
|
|
306
|
-
} else {
|
|
307
|
-
return Promise.reject(error);
|
|
308
302
|
}
|
|
309
|
-
|
|
303
|
+
return Promise.reject(error);
|
|
304
|
+
}
|
|
310
305
|
}
|
|
311
306
|
defaultVerificationEmail({
|
|
312
307
|
link,
|
|
@@ -347,14 +342,14 @@ function updateUserPassword(user, password, config) {
|
|
|
347
342
|
password: password
|
|
348
343
|
}).then(() => user);
|
|
349
344
|
}
|
|
350
|
-
function buildEmailLink(destination,
|
|
351
|
-
|
|
345
|
+
function buildEmailLink(destination, token, config) {
|
|
346
|
+
token = `token=${token}`;
|
|
352
347
|
if (config.parseFrameURL) {
|
|
353
348
|
const destinationWithoutHost = destination.replace(config.publicServerURL, '');
|
|
354
|
-
return `${config.parseFrameURL}?link=${encodeURIComponent(destinationWithoutHost)}&${
|
|
349
|
+
return `${config.parseFrameURL}?link=${encodeURIComponent(destinationWithoutHost)}&${token}`;
|
|
355
350
|
} else {
|
|
356
|
-
return `${destination}?${
|
|
351
|
+
return `${destination}?${token}`;
|
|
357
352
|
}
|
|
358
353
|
}
|
|
359
354
|
var _default = exports.default = UserController;
|
|
360
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_cryptoUtils","require","_triggers","_AdaptableController","_interopRequireDefault","_MailAdapter","_rest","_node","_AccountLockout","_Config","e","__esModule","default","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","undefined","query","updateFields","__op","$gt","Date","maintenanceAuth","maintenance","findUserForEmailVerification","method","Method","auth","className","restWhere","execute","then","result","results","length","objectId","rest","update","checkResetTokenValidity","database","find","_perishable_token","limit","passwordPolicy","resetTokenValidityDuration","expiresDate","_perishable_token_expires_at","__type","iso","getUserIfNeeded","where","email","runBeforeFind","master","encodeURIComponent","fetchedUser","sendUserEmailVerification","response","Object","fromJSON","isMaster","link","buildEmailLink","verifyEmailURL","appName","inflate","sendMail","defaultVerificationEmail","regenerateEmailVerifyToken","installationId","ip","emailVerifyTokenReuseIfValid","shouldSend","object","User","assign","resendRequest","resendVerificationEmail","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    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    const result = await query.execute();\n    if (result.results.length != 1) {\n      throw undefined;\n    }\n    return result.results[0];\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; only use the `fetchedUser`\n    // from this point onwards; do not use the `user` as it may not contain all fields.\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(fetchedUser.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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","ignoreList":[]}
|
|
355
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_cryptoUtils","require","_triggers","_AdaptableController","_interopRequireDefault","_MailAdapter","_rest","_node","_AccountLockout","_Config","e","__esModule","default","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","token","undefined","query","updateFields","__op","$gt","Date","maintenanceAuth","maintenance","restQuery","method","Method","auth","className","restWhere","result","execute","results","length","objectId","rest","update","checkResetTokenValidity","database","find","_perishable_token","limit","passwordPolicy","resetTokenValidityDuration","expiresDate","_perishable_token_expires_at","__type","iso","getUserIfNeeded","where","username","email","runBeforeFind","master","encodeURIComponent","fetchedUser","sendUserEmailVerification","response","Object","fromJSON","isMaster","link","buildEmailLink","verifyEmailURL","appName","inflate","sendMail","defaultVerificationEmail","regenerateEmailVerifyToken","installationId","ip","emailVerifyTokenReuseIfValid","shouldSend","object","User","assign","resendRequest","resendVerificationEmail","aUser","generate","setPasswordResetToken","generatePasswordResetTokenExpiresAt","$or","$exists","sendPasswordResetEmail","resetTokenReuseIfValid","requestResetPasswordURL","defaultResetPasswordEmail","updatePassword","password","rawUser","updateUserPassword","accountLockoutPolicy","AccountLockout","unlockAccount","error","message","reject","text","to","subject","exports","then","destination","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(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 = { _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    const restQuery = await RestQuery({\n      method: RestQuery.Method.get,\n      config: this.config,\n      auth: maintenanceAuth,\n      className: '_User',\n      restWhere: query,\n    });\n\n    const result = await restQuery.execute();\n    if (result.results.length) {\n      query.objectId = result.results[0].objectId;\n    }\n    return await rest.update(this.config, maintenanceAuth, '_User', query, updateFields);\n  }\n\n  async checkResetTokenValidity(token) {\n    const results = await this.config.database.find(\n      '_User',\n      {\n        _perishable_token: token,\n      },\n      { limit: 1 },\n      Auth.maintenance(this.config)\n    );\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()) {\n        throw 'The password reset link has expired';\n      }\n    }\n\n    return results[0];\n  }\n\n  async getUserIfNeeded(user) {\n    var where = {};\n    if (user.username) {\n      where.username = user.username;\n    }\n    if (user.email) {\n      where.email = user.email;\n    }\n    if (user._email_verify_token) {\n      where._email_verify_token = user._email_verify_token;\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    const result = await query.execute();\n    if (result.results.length != 1) {\n      throw undefined;\n    }\n    return result.results[0];\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; only use the `fetchedUser`\n    // from this point onwards; do not use the `user` as it may not contain all fields.\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 link = buildEmailLink(this.config.verifyEmailURL, 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, token) {\n    const aUser = await this.getUserIfNeeded({ username, _email_verify_token: token });\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\n    const link = buildEmailLink(this.config.requestResetPasswordURL, 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  async updatePassword(token, password) {\n    try {\n      const rawUser = await this.checkResetTokenValidity(token);\n      const user = await updateUserPassword(rawUser, password, this.config);\n\n      const accountLockoutPolicy = new AccountLockout(user, this.config);\n      return await accountLockoutPolicy.unlockAccount();\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      }\n      return Promise.reject(error);\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, token, config) {\n  token = `token=${token}`;\n  if (config.parseFrameURL) {\n    const destinationWithoutHost = destination.replace(config.publicServerURL, '');\n\n    return `${config.parseFrameURL}?link=${encodeURIComponent(destinationWithoutHost)}&${token}`;\n  } else {\n    return `${destination}?${token}`;\n  }\n}\n\nexport default UserController;\n"],"mappings":"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","ignoreList":[]}
|
|
@@ -313,16 +313,12 @@ const load = parseGraphQLSchema => {
|
|
|
313
313
|
}
|
|
314
314
|
},
|
|
315
315
|
mutateAndGetPayload: async ({
|
|
316
|
-
username,
|
|
317
316
|
password,
|
|
318
317
|
token
|
|
319
318
|
}, context) => {
|
|
320
319
|
const {
|
|
321
320
|
config
|
|
322
321
|
} = context;
|
|
323
|
-
if (!username) {
|
|
324
|
-
throw new _node.default.Error(_node.default.Error.USERNAME_MISSING, 'you must provide a username');
|
|
325
|
-
}
|
|
326
322
|
if (!password) {
|
|
327
323
|
throw new _node.default.Error(_node.default.Error.PASSWORD_MISSING, 'you must provide a password');
|
|
328
324
|
}
|
|
@@ -330,7 +326,7 @@ const load = parseGraphQLSchema => {
|
|
|
330
326
|
throw new _node.default.Error(_node.default.Error.OTHER_CAUSE, 'you must provide a token');
|
|
331
327
|
}
|
|
332
328
|
const userController = config.userController;
|
|
333
|
-
await userController.updatePassword(
|
|
329
|
+
await userController.updatePassword(token, password);
|
|
334
330
|
return {
|
|
335
331
|
ok: true
|
|
336
332
|
};
|
|
@@ -435,4 +431,4 @@ const load = parseGraphQLSchema => {
|
|
|
435
431
|
parseGraphQLSchema.addGraphQLMutation('challenge', challengeMutation, true, true);
|
|
436
432
|
};
|
|
437
433
|
exports.load = load;
|
|
438
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_graphql","require","_graphqlRelay","_deepcopy","_interopRequireDefault","_UsersRouter","objectsMutations","_interopRequireWildcard","_defaultGraphQLTypes","_usersQueries","_mutation","_node","_getRequireWildcardCache","e","WeakMap","r","t","__esModule","default","has","get","n","__proto__","a","Object","defineProperty","getOwnPropertyDescriptor","u","hasOwnProperty","call","i","set","usersRouter","UsersRouter","load","parseGraphQLSchema","isUsersClassDisabled","signUpMutation","mutationWithClientMutationId","name","description","inputFields","fields","descriptions","type","parseClassTypes","classGraphQLCreateType","outputFields","viewer","GraphQLNonNull","viewerType","mutateAndGetPayload","args","context","mutationInfo","deepcopy","config","auth","info","parseFields","transformTypes","className","originalFields","req","sessionToken","objectId","authDataResponse","createObject","getUserFromSessionToken","user","handleError","addGraphQLType","input","ofType","addGraphQLMutation","logInWithMutation","authData","OBJECT","GraphQLInputObjectType","classGraphQLCreateFields","getFields","keys","reduce","fieldName","logInMutation","username","GraphQLString","password","handleLogIn","body","query","response","logOutMutation","ok","GraphQLBoolean","_args","handleLogOut","resetPasswordMutation","email","handleResetRequest","confirmResetPasswordMutation","token","Parse","Error","USERNAME_MISSING","PASSWORD_MISSING","OTHER_CAUSE","userController","updatePassword","sendVerificationEmailMutation","handleVerificationEmailRequest","challengeMutation","challengeData","handleChallenge","exports"],"sources":["../../../src/GraphQL/loaders/usersMutations.js"],"sourcesContent":["import { GraphQLNonNull, GraphQLString, GraphQLBoolean, GraphQLInputObjectType } from 'graphql';\nimport { mutationWithClientMutationId } from 'graphql-relay';\nimport deepcopy from 'deepcopy';\nimport UsersRouter from '../../Routers/UsersRouter';\nimport * as objectsMutations from '../helpers/objectsMutations';\nimport { OBJECT } from './defaultGraphQLTypes';\nimport { getUserFromSessionToken } from './usersQueries';\nimport { transformTypes } from '../transformers/mutation';\nimport Parse from 'parse/node';\n\nconst usersRouter = new UsersRouter();\n\nconst load = parseGraphQLSchema => {\n  if (parseGraphQLSchema.isUsersClassDisabled) {\n    return;\n  }\n\n  const signUpMutation = mutationWithClientMutationId({\n    name: 'SignUp',\n    description: 'The signUp mutation can be used to create and sign up a new user.',\n    inputFields: {\n      fields: {\n        descriptions: 'These are the fields of the new user to be created and signed up.',\n        type: parseGraphQLSchema.parseClassTypes['_User'].classGraphQLCreateType,\n      },\n    },\n    outputFields: {\n      viewer: {\n        description: 'This is the new user that was created, signed up and returned as a viewer.',\n        type: new GraphQLNonNull(parseGraphQLSchema.viewerType),\n      },\n    },\n    mutateAndGetPayload: async (args, context, mutationInfo) => {\n      try {\n        const { fields } = deepcopy(args);\n        const { config, auth, info } = context;\n\n        const parseFields = await transformTypes('create', fields, {\n          className: '_User',\n          parseGraphQLSchema,\n          originalFields: args.fields,\n          req: { config, auth, info },\n        });\n\n        const { sessionToken, objectId, authDataResponse } = await objectsMutations.createObject(\n          '_User',\n          parseFields,\n          config,\n          auth,\n          info\n        );\n\n        context.info.sessionToken = sessionToken;\n        const viewer = await getUserFromSessionToken(\n          context,\n          mutationInfo,\n          'viewer.user.',\n          objectId\n        );\n        if (authDataResponse && viewer.user) { viewer.user.authDataResponse = authDataResponse; }\n        return {\n          viewer,\n        };\n      } catch (e) {\n        parseGraphQLSchema.handleError(e);\n      }\n    },\n  });\n\n  parseGraphQLSchema.addGraphQLType(signUpMutation.args.input.type.ofType, true, true);\n  parseGraphQLSchema.addGraphQLType(signUpMutation.type, true, true);\n  parseGraphQLSchema.addGraphQLMutation('signUp', signUpMutation, true, true);\n  const logInWithMutation = mutationWithClientMutationId({\n    name: 'LogInWith',\n    description:\n      'The logInWith mutation can be used to signup, login user with 3rd party authentication system. This mutation create a user if the authData do not correspond to an existing one.',\n    inputFields: {\n      authData: {\n        descriptions: 'This is the auth data of your custom auth provider',\n        type: new GraphQLNonNull(OBJECT),\n      },\n      fields: {\n        descriptions: 'These are the fields of the user to be created/updated and logged in.',\n        type: new GraphQLInputObjectType({\n          name: 'UserLoginWithInput',\n          fields: () => {\n            const classGraphQLCreateFields = parseGraphQLSchema.parseClassTypes[\n              '_User'\n            ].classGraphQLCreateType.getFields();\n            return Object.keys(classGraphQLCreateFields).reduce((fields, fieldName) => {\n              if (\n                fieldName !== 'password' &&\n                fieldName !== 'username' &&\n                fieldName !== 'authData'\n              ) {\n                fields[fieldName] = classGraphQLCreateFields[fieldName];\n              }\n              return fields;\n            }, {});\n          },\n        }),\n      },\n    },\n    outputFields: {\n      viewer: {\n        description: 'This is the new user that was created, signed up and returned as a viewer.',\n        type: new GraphQLNonNull(parseGraphQLSchema.viewerType),\n      },\n    },\n    mutateAndGetPayload: async (args, context, mutationInfo) => {\n      try {\n        const { fields, authData } = deepcopy(args);\n        const { config, auth, info } = context;\n\n        const parseFields = await transformTypes('create', fields, {\n          className: '_User',\n          parseGraphQLSchema,\n          originalFields: args.fields,\n          req: { config, auth, info },\n        });\n\n        const { sessionToken, objectId, authDataResponse } = await objectsMutations.createObject(\n          '_User',\n          { ...parseFields, authData },\n          config,\n          auth,\n          info\n        );\n\n        context.info.sessionToken = sessionToken;\n        const viewer = await getUserFromSessionToken(\n          context,\n          mutationInfo,\n          'viewer.user.',\n          objectId\n        );\n        if (authDataResponse && viewer.user) { viewer.user.authDataResponse = authDataResponse; }\n        return {\n          viewer,\n        };\n      } catch (e) {\n        parseGraphQLSchema.handleError(e);\n      }\n    },\n  });\n\n  parseGraphQLSchema.addGraphQLType(logInWithMutation.args.input.type.ofType, true, true);\n  parseGraphQLSchema.addGraphQLType(logInWithMutation.type, true, true);\n  parseGraphQLSchema.addGraphQLMutation('logInWith', logInWithMutation, true, true);\n\n  const logInMutation = mutationWithClientMutationId({\n    name: 'LogIn',\n    description: 'The logIn mutation can be used to log in an existing user.',\n    inputFields: {\n      username: {\n        description: 'This is the username used to log in the user.',\n        type: new GraphQLNonNull(GraphQLString),\n      },\n      password: {\n        description: 'This is the password used to log in the user.',\n        type: new GraphQLNonNull(GraphQLString),\n      },\n      authData: {\n        description: 'Auth data payload, needed if some required auth adapters are configured.',\n        type: OBJECT,\n      },\n    },\n    outputFields: {\n      viewer: {\n        description: 'This is the existing user that was logged in and returned as a viewer.',\n        type: new GraphQLNonNull(parseGraphQLSchema.viewerType),\n      },\n    },\n    mutateAndGetPayload: async (args, context, mutationInfo) => {\n      try {\n        const { username, password, authData } = deepcopy(args);\n        const { config, auth, info } = context;\n\n        const { sessionToken, objectId, authDataResponse } = (\n          await usersRouter.handleLogIn({\n            body: {\n              username,\n              password,\n              authData,\n            },\n            query: {},\n            config,\n            auth,\n            info,\n          })\n        ).response;\n\n        context.info.sessionToken = sessionToken;\n\n        const viewer = await getUserFromSessionToken(\n          context,\n          mutationInfo,\n          'viewer.user.',\n          objectId\n        );\n        if (authDataResponse && viewer.user) { viewer.user.authDataResponse = authDataResponse; }\n        return {\n          viewer,\n        };\n      } catch (e) {\n        parseGraphQLSchema.handleError(e);\n      }\n    },\n  });\n\n  parseGraphQLSchema.addGraphQLType(logInMutation.args.input.type.ofType, true, true);\n  parseGraphQLSchema.addGraphQLType(logInMutation.type, true, true);\n  parseGraphQLSchema.addGraphQLMutation('logIn', logInMutation, true, true);\n\n  const logOutMutation = mutationWithClientMutationId({\n    name: 'LogOut',\n    description: 'The logOut mutation can be used to log out an existing user.',\n    outputFields: {\n      ok: {\n        description: \"It's always true.\",\n        type: new GraphQLNonNull(GraphQLBoolean),\n      },\n    },\n    mutateAndGetPayload: async (_args, context) => {\n      try {\n        const { config, auth, info } = context;\n\n        await usersRouter.handleLogOut({\n          config,\n          auth,\n          info,\n        });\n\n        return { ok: true };\n      } catch (e) {\n        parseGraphQLSchema.handleError(e);\n      }\n    },\n  });\n\n  parseGraphQLSchema.addGraphQLType(logOutMutation.args.input.type.ofType, true, true);\n  parseGraphQLSchema.addGraphQLType(logOutMutation.type, true, true);\n  parseGraphQLSchema.addGraphQLMutation('logOut', logOutMutation, true, true);\n\n  const resetPasswordMutation = mutationWithClientMutationId({\n    name: 'ResetPassword',\n    description:\n      'The resetPassword mutation can be used to reset the password of an existing user.',\n    inputFields: {\n      email: {\n        descriptions: 'Email of the user that should receive the reset email',\n        type: new GraphQLNonNull(GraphQLString),\n      },\n    },\n    outputFields: {\n      ok: {\n        description: \"It's always true.\",\n        type: new GraphQLNonNull(GraphQLBoolean),\n      },\n    },\n    mutateAndGetPayload: async ({ email }, context) => {\n      const { config, auth, info } = context;\n\n      await usersRouter.handleResetRequest({\n        body: {\n          email,\n        },\n        config,\n        auth,\n        info,\n      });\n\n      return { ok: true };\n    },\n  });\n\n  parseGraphQLSchema.addGraphQLType(resetPasswordMutation.args.input.type.ofType, true, true);\n  parseGraphQLSchema.addGraphQLType(resetPasswordMutation.type, true, true);\n  parseGraphQLSchema.addGraphQLMutation('resetPassword', resetPasswordMutation, true, true);\n\n  const confirmResetPasswordMutation = mutationWithClientMutationId({\n    name: 'ConfirmResetPassword',\n    description:\n      'The confirmResetPassword mutation can be used to reset the password of an existing user.',\n    inputFields: {\n      username: {\n        descriptions: 'Username of the user that have received the reset email',\n        type: new GraphQLNonNull(GraphQLString),\n      },\n      password: {\n        descriptions: 'New password of the user',\n        type: new GraphQLNonNull(GraphQLString),\n      },\n      token: {\n        descriptions: 'Reset token that was emailed to the user',\n        type: new GraphQLNonNull(GraphQLString),\n      },\n    },\n    outputFields: {\n      ok: {\n        description: \"It's always true.\",\n        type: new GraphQLNonNull(GraphQLBoolean),\n      },\n    },\n    mutateAndGetPayload: async ({ username, password, token }, context) => {\n      const { config } = context;\n      if (!username) {\n        throw new Parse.Error(Parse.Error.USERNAME_MISSING, 'you must provide a username');\n      }\n      if (!password) {\n        throw new Parse.Error(Parse.Error.PASSWORD_MISSING, 'you must provide a password');\n      }\n      if (!token) {\n        throw new Parse.Error(Parse.Error.OTHER_CAUSE, 'you must provide a token');\n      }\n\n      const userController = config.userController;\n      await userController.updatePassword(username, token, password);\n      return { ok: true };\n    },\n  });\n\n  parseGraphQLSchema.addGraphQLType(\n    confirmResetPasswordMutation.args.input.type.ofType,\n    true,\n    true\n  );\n  parseGraphQLSchema.addGraphQLType(confirmResetPasswordMutation.type, true, true);\n  parseGraphQLSchema.addGraphQLMutation(\n    'confirmResetPassword',\n    confirmResetPasswordMutation,\n    true,\n    true\n  );\n\n  const sendVerificationEmailMutation = mutationWithClientMutationId({\n    name: 'SendVerificationEmail',\n    description:\n      'The sendVerificationEmail mutation can be used to send the verification email again.',\n    inputFields: {\n      email: {\n        descriptions: 'Email of the user that should receive the verification email',\n        type: new GraphQLNonNull(GraphQLString),\n      },\n    },\n    outputFields: {\n      ok: {\n        description: \"It's always true.\",\n        type: new GraphQLNonNull(GraphQLBoolean),\n      },\n    },\n    mutateAndGetPayload: async ({ email }, context) => {\n      try {\n        const { config, auth, info } = context;\n\n        await usersRouter.handleVerificationEmailRequest({\n          body: {\n            email,\n          },\n          config,\n          auth,\n          info,\n        });\n\n        return { ok: true };\n      } catch (e) {\n        parseGraphQLSchema.handleError(e);\n      }\n    },\n  });\n\n  parseGraphQLSchema.addGraphQLType(\n    sendVerificationEmailMutation.args.input.type.ofType,\n    true,\n    true\n  );\n  parseGraphQLSchema.addGraphQLType(sendVerificationEmailMutation.type, true, true);\n  parseGraphQLSchema.addGraphQLMutation(\n    'sendVerificationEmail',\n    sendVerificationEmailMutation,\n    true,\n    true\n  );\n\n  const challengeMutation = mutationWithClientMutationId({\n    name: 'Challenge',\n    description:\n      'The challenge mutation can be used to initiate an authentication challenge when an auth adapter needs it.',\n    inputFields: {\n      username: {\n        description: 'This is the username used to log in the user.',\n        type: GraphQLString,\n      },\n      password: {\n        description: 'This is the password used to log in the user.',\n        type: GraphQLString,\n      },\n      authData: {\n        description:\n          'Auth data allow to preidentify the user if the auth adapter needs preidentification.',\n        type: OBJECT,\n      },\n      challengeData: {\n        description:\n          'Challenge data payload, can be used to post data to auth providers to auth providers if they need data for the response.',\n        type: OBJECT,\n      },\n    },\n    outputFields: {\n      challengeData: {\n        description: 'Challenge response from configured auth adapters.',\n        type: OBJECT,\n      },\n    },\n    mutateAndGetPayload: async (input, context) => {\n      try {\n        const { config, auth, info } = context;\n\n        const { response } = await usersRouter.handleChallenge({\n          body: input,\n          config,\n          auth,\n          info,\n        });\n        return response;\n      } catch (e) {\n        parseGraphQLSchema.handleError(e);\n      }\n    },\n  });\n\n  parseGraphQLSchema.addGraphQLType(challengeMutation.args.input.type.ofType, true, true);\n  parseGraphQLSchema.addGraphQLType(challengeMutation.type, true, true);\n  parseGraphQLSchema.addGraphQLMutation('challenge', challengeMutation, true, true);\n};\n\nexport { load };\n"],"mappings":";;;;;;AAAA,IAAAA,QAAA,GAAAC,OAAA;AACA,IAAAC,aAAA,GAAAD,OAAA;AACA,IAAAE,SAAA,GAAAC,sBAAA,CAAAH,OAAA;AACA,IAAAI,YAAA,GAAAD,sBAAA,CAAAH,OAAA;AACA,IAAAK,gBAAA,GAAAC,uBAAA,CAAAN,OAAA;AACA,IAAAO,oBAAA,GAAAP,OAAA;AACA,IAAAQ,aAAA,GAAAR,OAAA;AACA,IAAAS,SAAA,GAAAT,OAAA;AACA,IAAAU,KAAA,GAAAP,sBAAA,CAAAH,OAAA;AAA+B,SAAAW,yBAAAC,CAAA,6BAAAC,OAAA,mBAAAC,CAAA,OAAAD,OAAA,IAAAE,CAAA,OAAAF,OAAA,YAAAF,wBAAA,YAAAA,CAAAC,CAAA,WAAAA,CAAA,GAAAG,CAAA,GAAAD,CAAA,KAAAF,CAAA;AAAA,SAAAN,wBAAAM,CAAA,EAAAE,CAAA,SAAAA,CAAA,IAAAF,CAAA,IAAAA,CAAA,CAAAI,UAAA,SAAAJ,CAAA,eAAAA,CAAA,uBAAAA,CAAA,yBAAAA,CAAA,WAAAK,OAAA,EAAAL,CAAA,QAAAG,CAAA,GAAAJ,wBAAA,CAAAG,CAAA,OAAAC,CAAA,IAAAA,CAAA,CAAAG,GAAA,CAAAN,CAAA,UAAAG,CAAA,CAAAI,GAAA,CAAAP,CAAA,OAAAQ,CAAA,KAAAC,SAAA,UAAAC,CAAA,GAAAC,MAAA,CAAAC,cAAA,IAAAD,MAAA,CAAAE,wBAAA,WAAAC,CAAA,IAAAd,CAAA,oBAAAc,CAAA,OAAAC,cAAA,CAAAC,IAAA,CAAAhB,CAAA,EAAAc,CAAA,SAAAG,CAAA,GAAAP,CAAA,GAAAC,MAAA,CAAAE,wBAAA,CAAAb,CAAA,EAAAc,CAAA,UAAAG,CAAA,KAAAA,CAAA,CAAAV,GAAA,IAAAU,CAAA,CAAAC,GAAA,IAAAP,MAAA,CAAAC,cAAA,CAAAJ,CAAA,EAAAM,CAAA,EAAAG,CAAA,IAAAT,CAAA,CAAAM,CAAA,IAAAd,CAAA,CAAAc,CAAA,YAAAN,CAAA,CAAAH,OAAA,GAAAL,CAAA,EAAAG,CAAA,IAAAA,CAAA,CAAAe,GAAA,CAAAlB,CAAA,EAAAQ,CAAA,GAAAA,CAAA;AAAA,SAAAjB,uBAAAS,CAAA,WAAAA,CAAA,IAAAA,CAAA,CAAAI,UAAA,GAAAJ,CAAA,KAAAK,OAAA,EAAAL,CAAA;AAE/B,MAAMmB,WAAW,GAAG,IAAIC,oBAAW,CAAC,CAAC;AAErC,MAAMC,IAAI,GAAGC,kBAAkB,IAAI;EACjC,IAAIA,kBAAkB,CAACC,oBAAoB,EAAE;IAC3C;EACF;EAEA,MAAMC,cAAc,GAAG,IAAAC,0CAA4B,EAAC;IAClDC,IAAI,EAAE,QAAQ;IACdC,WAAW,EAAE,mEAAmE;IAChFC,WAAW,EAAE;MACXC,MAAM,EAAE;QACNC,YAAY,EAAE,mEAAmE;QACjFC,IAAI,EAAET,kBAAkB,CAACU,eAAe,CAAC,OAAO,CAAC,CAACC;MACpD;IACF,CAAC;IACDC,YAAY,EAAE;MACZC,MAAM,EAAE;QACNR,WAAW,EAAE,4EAA4E;QACzFI,IAAI,EAAE,IAAIK,uBAAc,CAACd,kBAAkB,CAACe,UAAU;MACxD;IACF,CAAC;IACDC,mBAAmB,EAAE,MAAAA,CAAOC,IAAI,EAAEC,OAAO,EAAEC,YAAY,KAAK;MAC1D,IAAI;QACF,MAAM;UAAEZ;QAAO,CAAC,GAAG,IAAAa,iBAAQ,EAACH,IAAI,CAAC;QACjC,MAAM;UAAEI,MAAM;UAAEC,IAAI;UAAEC;QAAK,CAAC,GAAGL,OAAO;QAEtC,MAAMM,WAAW,GAAG,MAAM,IAAAC,wBAAc,EAAC,QAAQ,EAAElB,MAAM,EAAE;UACzDmB,SAAS,EAAE,OAAO;UAClB1B,kBAAkB;UAClB2B,cAAc,EAAEV,IAAI,CAACV,MAAM;UAC3BqB,GAAG,EAAE;YAAEP,MAAM;YAAEC,IAAI;YAAEC;UAAK;QAC5B,CAAC,CAAC;QAEF,MAAM;UAAEM,YAAY;UAAEC,QAAQ;UAAEC;QAAiB,CAAC,GAAG,MAAM5D,gBAAgB,CAAC6D,YAAY,CACtF,OAAO,EACPR,WAAW,EACXH,MAAM,EACNC,IAAI,EACJC,IACF,CAAC;QAEDL,OAAO,CAACK,IAAI,CAACM,YAAY,GAAGA,YAAY;QACxC,MAAMhB,MAAM,GAAG,MAAM,IAAAoB,qCAAuB,EAC1Cf,OAAO,EACPC,YAAY,EACZ,cAAc,EACdW,QACF,CAAC;QACD,IAAIC,gBAAgB,IAAIlB,MAAM,CAACqB,IAAI,EAAE;UAAErB,MAAM,CAACqB,IAAI,CAACH,gBAAgB,GAAGA,gBAAgB;QAAE;QACxF,OAAO;UACLlB;QACF,CAAC;MACH,CAAC,CAAC,OAAOnC,CAAC,EAAE;QACVsB,kBAAkB,CAACmC,WAAW,CAACzD,CAAC,CAAC;MACnC;IACF;EACF,CAAC,CAAC;EAEFsB,kBAAkB,CAACoC,cAAc,CAAClC,cAAc,CAACe,IAAI,CAACoB,KAAK,CAAC5B,IAAI,CAAC6B,MAAM,EAAE,IAAI,EAAE,IAAI,CAAC;EACpFtC,kBAAkB,CAACoC,cAAc,CAAClC,cAAc,CAACO,IAAI,EAAE,IAAI,EAAE,IAAI,CAAC;EAClET,kBAAkB,CAACuC,kBAAkB,CAAC,QAAQ,EAAErC,cAAc,EAAE,IAAI,EAAE,IAAI,CAAC;EAC3E,MAAMsC,iBAAiB,GAAG,IAAArC,0CAA4B,EAAC;IACrDC,IAAI,EAAE,WAAW;IACjBC,WAAW,EACT,kLAAkL;IACpLC,WAAW,EAAE;MACXmC,QAAQ,EAAE;QACRjC,YAAY,EAAE,oDAAoD;QAClEC,IAAI,EAAE,IAAIK,uBAAc,CAAC4B,2BAAM;MACjC,CAAC;MACDnC,MAAM,EAAE;QACNC,YAAY,EAAE,uEAAuE;QACrFC,IAAI,EAAE,IAAIkC,+BAAsB,CAAC;UAC/BvC,IAAI,EAAE,oBAAoB;UAC1BG,MAAM,EAAEA,CAAA,KAAM;YACZ,MAAMqC,wBAAwB,GAAG5C,kBAAkB,CAACU,eAAe,CACjE,OAAO,CACR,CAACC,sBAAsB,CAACkC,SAAS,CAAC,CAAC;YACpC,OAAOxD,MAAM,CAACyD,IAAI,CAACF,wBAAwB,CAAC,CAACG,MAAM,CAAC,CAACxC,MAAM,EAAEyC,SAAS,KAAK;cACzE,IACEA,SAAS,KAAK,UAAU,IACxBA,SAAS,KAAK,UAAU,IACxBA,SAAS,KAAK,UAAU,EACxB;gBACAzC,MAAM,CAACyC,SAAS,CAAC,GAAGJ,wBAAwB,CAACI,SAAS,CAAC;cACzD;cACA,OAAOzC,MAAM;YACf,CAAC,EAAE,CAAC,CAAC,CAAC;UACR;QACF,CAAC;MACH;IACF,CAAC;IACDK,YAAY,EAAE;MACZC,MAAM,EAAE;QACNR,WAAW,EAAE,4EAA4E;QACzFI,IAAI,EAAE,IAAIK,uBAAc,CAACd,kBAAkB,CAACe,UAAU;MACxD;IACF,CAAC;IACDC,mBAAmB,EAAE,MAAAA,CAAOC,IAAI,EAAEC,OAAO,EAAEC,YAAY,KAAK;MAC1D,IAAI;QACF,MAAM;UAAEZ,MAAM;UAAEkC;QAAS,CAAC,GAAG,IAAArB,iBAAQ,EAACH,IAAI,CAAC;QAC3C,MAAM;UAAEI,MAAM;UAAEC,IAAI;UAAEC;QAAK,CAAC,GAAGL,OAAO;QAEtC,MAAMM,WAAW,GAAG,MAAM,IAAAC,wBAAc,EAAC,QAAQ,EAAElB,MAAM,EAAE;UACzDmB,SAAS,EAAE,OAAO;UAClB1B,kBAAkB;UAClB2B,cAAc,EAAEV,IAAI,CAACV,MAAM;UAC3BqB,GAAG,EAAE;YAAEP,MAAM;YAAEC,IAAI;YAAEC;UAAK;QAC5B,CAAC,CAAC;QAEF,MAAM;UAAEM,YAAY;UAAEC,QAAQ;UAAEC;QAAiB,CAAC,GAAG,MAAM5D,gBAAgB,CAAC6D,YAAY,CACtF,OAAO,EACP;UAAE,GAAGR,WAAW;UAAEiB;QAAS,CAAC,EAC5BpB,MAAM,EACNC,IAAI,EACJC,IACF,CAAC;QAEDL,OAAO,CAACK,IAAI,CAACM,YAAY,GAAGA,YAAY;QACxC,MAAMhB,MAAM,GAAG,MAAM,IAAAoB,qCAAuB,EAC1Cf,OAAO,EACPC,YAAY,EACZ,cAAc,EACdW,QACF,CAAC;QACD,IAAIC,gBAAgB,IAAIlB,MAAM,CAACqB,IAAI,EAAE;UAAErB,MAAM,CAACqB,IAAI,CAACH,gBAAgB,GAAGA,gBAAgB;QAAE;QACxF,OAAO;UACLlB;QACF,CAAC;MACH,CAAC,CAAC,OAAOnC,CAAC,EAAE;QACVsB,kBAAkB,CAACmC,WAAW,CAACzD,CAAC,CAAC;MACnC;IACF;EACF,CAAC,CAAC;EAEFsB,kBAAkB,CAACoC,cAAc,CAACI,iBAAiB,CAACvB,IAAI,CAACoB,KAAK,CAAC5B,IAAI,CAAC6B,MAAM,EAAE,IAAI,EAAE,IAAI,CAAC;EACvFtC,kBAAkB,CAACoC,cAAc,CAACI,iBAAiB,CAAC/B,IAAI,EAAE,IAAI,EAAE,IAAI,CAAC;EACrET,kBAAkB,CAACuC,kBAAkB,CAAC,WAAW,EAAEC,iBAAiB,EAAE,IAAI,EAAE,IAAI,CAAC;EAEjF,MAAMS,aAAa,GAAG,IAAA9C,0CAA4B,EAAC;IACjDC,IAAI,EAAE,OAAO;IACbC,WAAW,EAAE,4DAA4D;IACzEC,WAAW,EAAE;MACX4C,QAAQ,EAAE;QACR7C,WAAW,EAAE,+CAA+C;QAC5DI,IAAI,EAAE,IAAIK,uBAAc,CAACqC,sBAAa;MACxC,CAAC;MACDC,QAAQ,EAAE;QACR/C,WAAW,EAAE,+CAA+C;QAC5DI,IAAI,EAAE,IAAIK,uBAAc,CAACqC,sBAAa;MACxC,CAAC;MACDV,QAAQ,EAAE;QACRpC,WAAW,EAAE,0EAA0E;QACvFI,IAAI,EAAEiC;MACR;IACF,CAAC;IACD9B,YAAY,EAAE;MACZC,MAAM,EAAE;QACNR,WAAW,EAAE,wEAAwE;QACrFI,IAAI,EAAE,IAAIK,uBAAc,CAACd,kBAAkB,CAACe,UAAU;MACxD;IACF,CAAC;IACDC,mBAAmB,EAAE,MAAAA,CAAOC,IAAI,EAAEC,OAAO,EAAEC,YAAY,KAAK;MAC1D,IAAI;QACF,MAAM;UAAE+B,QAAQ;UAAEE,QAAQ;UAAEX;QAAS,CAAC,GAAG,IAAArB,iBAAQ,EAACH,IAAI,CAAC;QACvD,MAAM;UAAEI,MAAM;UAAEC,IAAI;UAAEC;QAAK,CAAC,GAAGL,OAAO;QAEtC,MAAM;UAAEW,YAAY;UAAEC,QAAQ;UAAEC;QAAiB,CAAC,GAAG,CACnD,MAAMlC,WAAW,CAACwD,WAAW,CAAC;UAC5BC,IAAI,EAAE;YACJJ,QAAQ;YACRE,QAAQ;YACRX;UACF,CAAC;UACDc,KAAK,EAAE,CAAC,CAAC;UACTlC,MAAM;UACNC,IAAI;UACJC;QACF,CAAC,CAAC,EACFiC,QAAQ;QAEVtC,OAAO,CAACK,IAAI,CAACM,YAAY,GAAGA,YAAY;QAExC,MAAMhB,MAAM,GAAG,MAAM,IAAAoB,qCAAuB,EAC1Cf,OAAO,EACPC,YAAY,EACZ,cAAc,EACdW,QACF,CAAC;QACD,IAAIC,gBAAgB,IAAIlB,MAAM,CAACqB,IAAI,EAAE;UAAErB,MAAM,CAACqB,IAAI,CAACH,gBAAgB,GAAGA,gBAAgB;QAAE;QACxF,OAAO;UACLlB;QACF,CAAC;MACH,CAAC,CAAC,OAAOnC,CAAC,EAAE;QACVsB,kBAAkB,CAACmC,WAAW,CAACzD,CAAC,CAAC;MACnC;IACF;EACF,CAAC,CAAC;EAEFsB,kBAAkB,CAACoC,cAAc,CAACa,aAAa,CAAChC,IAAI,CAACoB,KAAK,CAAC5B,IAAI,CAAC6B,MAAM,EAAE,IAAI,EAAE,IAAI,CAAC;EACnFtC,kBAAkB,CAACoC,cAAc,CAACa,aAAa,CAACxC,IAAI,EAAE,IAAI,EAAE,IAAI,CAAC;EACjET,kBAAkB,CAACuC,kBAAkB,CAAC,OAAO,EAAEU,aAAa,EAAE,IAAI,EAAE,IAAI,CAAC;EAEzE,MAAMQ,cAAc,GAAG,IAAAtD,0CAA4B,EAAC;IAClDC,IAAI,EAAE,QAAQ;IACdC,WAAW,EAAE,8DAA8D;IAC3EO,YAAY,EAAE;MACZ8C,EAAE,EAAE;QACFrD,WAAW,EAAE,mBAAmB;QAChCI,IAAI,EAAE,IAAIK,uBAAc,CAAC6C,uBAAc;MACzC;IACF,CAAC;IACD3C,mBAAmB,EAAE,MAAAA,CAAO4C,KAAK,EAAE1C,OAAO,KAAK;MAC7C,IAAI;QACF,MAAM;UAAEG,MAAM;UAAEC,IAAI;UAAEC;QAAK,CAAC,GAAGL,OAAO;QAEtC,MAAMrB,WAAW,CAACgE,YAAY,CAAC;UAC7BxC,MAAM;UACNC,IAAI;UACJC;QACF,CAAC,CAAC;QAEF,OAAO;UAAEmC,EAAE,EAAE;QAAK,CAAC;MACrB,CAAC,CAAC,OAAOhF,CAAC,EAAE;QACVsB,kBAAkB,CAACmC,WAAW,CAACzD,CAAC,CAAC;MACnC;IACF;EACF,CAAC,CAAC;EAEFsB,kBAAkB,CAACoC,cAAc,CAACqB,cAAc,CAACxC,IAAI,CAACoB,KAAK,CAAC5B,IAAI,CAAC6B,MAAM,EAAE,IAAI,EAAE,IAAI,CAAC;EACpFtC,kBAAkB,CAACoC,cAAc,CAACqB,cAAc,CAAChD,IAAI,EAAE,IAAI,EAAE,IAAI,CAAC;EAClET,kBAAkB,CAACuC,kBAAkB,CAAC,QAAQ,EAAEkB,cAAc,EAAE,IAAI,EAAE,IAAI,CAAC;EAE3E,MAAMK,qBAAqB,GAAG,IAAA3D,0CAA4B,EAAC;IACzDC,IAAI,EAAE,eAAe;IACrBC,WAAW,EACT,mFAAmF;IACrFC,WAAW,EAAE;MACXyD,KAAK,EAAE;QACLvD,YAAY,EAAE,uDAAuD;QACrEC,IAAI,EAAE,IAAIK,uBAAc,CAACqC,sBAAa;MACxC;IACF,CAAC;IACDvC,YAAY,EAAE;MACZ8C,EAAE,EAAE;QACFrD,WAAW,EAAE,mBAAmB;QAChCI,IAAI,EAAE,IAAIK,uBAAc,CAAC6C,uBAAc;MACzC;IACF,CAAC;IACD3C,mBAAmB,EAAE,MAAAA,CAAO;MAAE+C;IAAM,CAAC,EAAE7C,OAAO,KAAK;MACjD,MAAM;QAAEG,MAAM;QAAEC,IAAI;QAAEC;MAAK,CAAC,GAAGL,OAAO;MAEtC,MAAMrB,WAAW,CAACmE,kBAAkB,CAAC;QACnCV,IAAI,EAAE;UACJS;QACF,CAAC;QACD1C,MAAM;QACNC,IAAI;QACJC;MACF,CAAC,CAAC;MAEF,OAAO;QAAEmC,EAAE,EAAE;MAAK,CAAC;IACrB;EACF,CAAC,CAAC;EAEF1D,kBAAkB,CAACoC,cAAc,CAAC0B,qBAAqB,CAAC7C,IAAI,CAACoB,KAAK,CAAC5B,IAAI,CAAC6B,MAAM,EAAE,IAAI,EAAE,IAAI,CAAC;EAC3FtC,kBAAkB,CAACoC,cAAc,CAAC0B,qBAAqB,CAACrD,IAAI,EAAE,IAAI,EAAE,IAAI,CAAC;EACzET,kBAAkB,CAACuC,kBAAkB,CAAC,eAAe,EAAEuB,qBAAqB,EAAE,IAAI,EAAE,IAAI,CAAC;EAEzF,MAAMG,4BAA4B,GAAG,IAAA9D,0CAA4B,EAAC;IAChEC,IAAI,EAAE,sBAAsB;IAC5BC,WAAW,EACT,0FAA0F;IAC5FC,WAAW,EAAE;MACX4C,QAAQ,EAAE;QACR1C,YAAY,EAAE,yDAAyD;QACvEC,IAAI,EAAE,IAAIK,uBAAc,CAACqC,sBAAa;MACxC,CAAC;MACDC,QAAQ,EAAE;QACR5C,YAAY,EAAE,0BAA0B;QACxCC,IAAI,EAAE,IAAIK,uBAAc,CAACqC,sBAAa;MACxC,CAAC;MACDe,KAAK,EAAE;QACL1D,YAAY,EAAE,0CAA0C;QACxDC,IAAI,EAAE,IAAIK,uBAAc,CAACqC,sBAAa;MACxC;IACF,CAAC;IACDvC,YAAY,EAAE;MACZ8C,EAAE,EAAE;QACFrD,WAAW,EAAE,mBAAmB;QAChCI,IAAI,EAAE,IAAIK,uBAAc,CAAC6C,uBAAc;MACzC;IACF,CAAC;IACD3C,mBAAmB,EAAE,MAAAA,CAAO;MAAEkC,QAAQ;MAAEE,QAAQ;MAAEc;IAAM,CAAC,EAAEhD,OAAO,KAAK;MACrE,MAAM;QAAEG;MAAO,CAAC,GAAGH,OAAO;MAC1B,IAAI,CAACgC,QAAQ,EAAE;QACb,MAAM,IAAIiB,aAAK,CAACC,KAAK,CAACD,aAAK,CAACC,KAAK,CAACC,gBAAgB,EAAE,6BAA6B,CAAC;MACpF;MACA,IAAI,CAACjB,QAAQ,EAAE;QACb,MAAM,IAAIe,aAAK,CAACC,KAAK,CAACD,aAAK,CAACC,KAAK,CAACE,gBAAgB,EAAE,6BAA6B,CAAC;MACpF;MACA,IAAI,CAACJ,KAAK,EAAE;QACV,MAAM,IAAIC,aAAK,CAACC,KAAK,CAACD,aAAK,CAACC,KAAK,CAACG,WAAW,EAAE,0BAA0B,CAAC;MAC5E;MAEA,MAAMC,cAAc,GAAGnD,MAAM,CAACmD,cAAc;MAC5C,MAAMA,cAAc,CAACC,cAAc,CAACvB,QAAQ,EAAEgB,KAAK,EAAEd,QAAQ,CAAC;MAC9D,OAAO;QAAEM,EAAE,EAAE;MAAK,CAAC;IACrB;EACF,CAAC,CAAC;EAEF1D,kBAAkB,CAACoC,cAAc,CAC/B6B,4BAA4B,CAAChD,IAAI,CAACoB,KAAK,CAAC5B,IAAI,CAAC6B,MAAM,EACnD,IAAI,EACJ,IACF,CAAC;EACDtC,kBAAkB,CAACoC,cAAc,CAAC6B,4BAA4B,CAACxD,IAAI,EAAE,IAAI,EAAE,IAAI,CAAC;EAChFT,kBAAkB,CAACuC,kBAAkB,CACnC,sBAAsB,EACtB0B,4BAA4B,EAC5B,IAAI,EACJ,IACF,CAAC;EAED,MAAMS,6BAA6B,GAAG,IAAAvE,0CAA4B,EAAC;IACjEC,IAAI,EAAE,uBAAuB;IAC7BC,WAAW,EACT,sFAAsF;IACxFC,WAAW,EAAE;MACXyD,KAAK,EAAE;QACLvD,YAAY,EAAE,8DAA8D;QAC5EC,IAAI,EAAE,IAAIK,uBAAc,CAACqC,sBAAa;MACxC;IACF,CAAC;IACDvC,YAAY,EAAE;MACZ8C,EAAE,EAAE;QACFrD,WAAW,EAAE,mBAAmB;QAChCI,IAAI,EAAE,IAAIK,uBAAc,CAAC6C,uBAAc;MACzC;IACF,CAAC;IACD3C,mBAAmB,EAAE,MAAAA,CAAO;MAAE+C;IAAM,CAAC,EAAE7C,OAAO,KAAK;MACjD,IAAI;QACF,MAAM;UAAEG,MAAM;UAAEC,IAAI;UAAEC;QAAK,CAAC,GAAGL,OAAO;QAEtC,MAAMrB,WAAW,CAAC8E,8BAA8B,CAAC;UAC/CrB,IAAI,EAAE;YACJS;UACF,CAAC;UACD1C,MAAM;UACNC,IAAI;UACJC;QACF,CAAC,CAAC;QAEF,OAAO;UAAEmC,EAAE,EAAE;QAAK,CAAC;MACrB,CAAC,CAAC,OAAOhF,CAAC,EAAE;QACVsB,kBAAkB,CAACmC,WAAW,CAACzD,CAAC,CAAC;MACnC;IACF;EACF,CAAC,CAAC;EAEFsB,kBAAkB,CAACoC,cAAc,CAC/BsC,6BAA6B,CAACzD,IAAI,CAACoB,KAAK,CAAC5B,IAAI,CAAC6B,MAAM,EACpD,IAAI,EACJ,IACF,CAAC;EACDtC,kBAAkB,CAACoC,cAAc,CAACsC,6BAA6B,CAACjE,IAAI,EAAE,IAAI,EAAE,IAAI,CAAC;EACjFT,kBAAkB,CAACuC,kBAAkB,CACnC,uBAAuB,EACvBmC,6BAA6B,EAC7B,IAAI,EACJ,IACF,CAAC;EAED,MAAME,iBAAiB,GAAG,IAAAzE,0CAA4B,EAAC;IACrDC,IAAI,EAAE,WAAW;IACjBC,WAAW,EACT,2GAA2G;IAC7GC,WAAW,EAAE;MACX4C,QAAQ,EAAE;QACR7C,WAAW,EAAE,+CAA+C;QAC5DI,IAAI,EAAE0C;MACR,CAAC;MACDC,QAAQ,EAAE;QACR/C,WAAW,EAAE,+CAA+C;QAC5DI,IAAI,EAAE0C;MACR,CAAC;MACDV,QAAQ,EAAE;QACRpC,WAAW,EACT,sFAAsF;QACxFI,IAAI,EAAEiC;MACR,CAAC;MACDmC,aAAa,EAAE;QACbxE,WAAW,EACT,0HAA0H;QAC5HI,IAAI,EAAEiC;MACR;IACF,CAAC;IACD9B,YAAY,EAAE;MACZiE,aAAa,EAAE;QACbxE,WAAW,EAAE,mDAAmD;QAChEI,IAAI,EAAEiC;MACR;IACF,CAAC;IACD1B,mBAAmB,EAAE,MAAAA,CAAOqB,KAAK,EAAEnB,OAAO,KAAK;MAC7C,IAAI;QACF,MAAM;UAAEG,MAAM;UAAEC,IAAI;UAAEC;QAAK,CAAC,GAAGL,OAAO;QAEtC,MAAM;UAAEsC;QAAS,CAAC,GAAG,MAAM3D,WAAW,CAACiF,eAAe,CAAC;UACrDxB,IAAI,EAAEjB,KAAK;UACXhB,MAAM;UACNC,IAAI;UACJC;QACF,CAAC,CAAC;QACF,OAAOiC,QAAQ;MACjB,CAAC,CAAC,OAAO9E,CAAC,EAAE;QACVsB,kBAAkB,CAACmC,WAAW,CAACzD,CAAC,CAAC;MACnC;IACF;EACF,CAAC,CAAC;EAEFsB,kBAAkB,CAACoC,cAAc,CAACwC,iBAAiB,CAAC3D,IAAI,CAACoB,KAAK,CAAC5B,IAAI,CAAC6B,MAAM,EAAE,IAAI,EAAE,IAAI,CAAC;EACvFtC,kBAAkB,CAACoC,cAAc,CAACwC,iBAAiB,CAACnE,IAAI,EAAE,IAAI,EAAE,IAAI,CAAC;EACrET,kBAAkB,CAACuC,kBAAkB,CAAC,WAAW,EAAEqC,iBAAiB,EAAE,IAAI,EAAE,IAAI,CAAC;AACnF,CAAC;AAACG,OAAA,CAAAhF,IAAA,GAAAA,IAAA","ignoreList":[]}
|
|
434
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_graphql","require","_graphqlRelay","_deepcopy","_interopRequireDefault","_UsersRouter","objectsMutations","_interopRequireWildcard","_defaultGraphQLTypes","_usersQueries","_mutation","_node","_getRequireWildcardCache","e","WeakMap","r","t","__esModule","default","has","get","n","__proto__","a","Object","defineProperty","getOwnPropertyDescriptor","u","hasOwnProperty","call","i","set","usersRouter","UsersRouter","load","parseGraphQLSchema","isUsersClassDisabled","signUpMutation","mutationWithClientMutationId","name","description","inputFields","fields","descriptions","type","parseClassTypes","classGraphQLCreateType","outputFields","viewer","GraphQLNonNull","viewerType","mutateAndGetPayload","args","context","mutationInfo","deepcopy","config","auth","info","parseFields","transformTypes","className","originalFields","req","sessionToken","objectId","authDataResponse","createObject","getUserFromSessionToken","user","handleError","addGraphQLType","input","ofType","addGraphQLMutation","logInWithMutation","authData","OBJECT","GraphQLInputObjectType","classGraphQLCreateFields","getFields","keys","reduce","fieldName","logInMutation","username","GraphQLString","password","handleLogIn","body","query","response","logOutMutation","ok","GraphQLBoolean","_args","handleLogOut","resetPasswordMutation","email","handleResetRequest","confirmResetPasswordMutation","token","Parse","Error","PASSWORD_MISSING","OTHER_CAUSE","userController","updatePassword","sendVerificationEmailMutation","handleVerificationEmailRequest","challengeMutation","challengeData","handleChallenge","exports"],"sources":["../../../src/GraphQL/loaders/usersMutations.js"],"sourcesContent":["import { GraphQLNonNull, GraphQLString, GraphQLBoolean, GraphQLInputObjectType } from 'graphql';\nimport { mutationWithClientMutationId } from 'graphql-relay';\nimport deepcopy from 'deepcopy';\nimport UsersRouter from '../../Routers/UsersRouter';\nimport * as objectsMutations from '../helpers/objectsMutations';\nimport { OBJECT } from './defaultGraphQLTypes';\nimport { getUserFromSessionToken } from './usersQueries';\nimport { transformTypes } from '../transformers/mutation';\nimport Parse from 'parse/node';\n\nconst usersRouter = new UsersRouter();\n\nconst load = parseGraphQLSchema => {\n  if (parseGraphQLSchema.isUsersClassDisabled) {\n    return;\n  }\n\n  const signUpMutation = mutationWithClientMutationId({\n    name: 'SignUp',\n    description: 'The signUp mutation can be used to create and sign up a new user.',\n    inputFields: {\n      fields: {\n        descriptions: 'These are the fields of the new user to be created and signed up.',\n        type: parseGraphQLSchema.parseClassTypes['_User'].classGraphQLCreateType,\n      },\n    },\n    outputFields: {\n      viewer: {\n        description: 'This is the new user that was created, signed up and returned as a viewer.',\n        type: new GraphQLNonNull(parseGraphQLSchema.viewerType),\n      },\n    },\n    mutateAndGetPayload: async (args, context, mutationInfo) => {\n      try {\n        const { fields } = deepcopy(args);\n        const { config, auth, info } = context;\n\n        const parseFields = await transformTypes('create', fields, {\n          className: '_User',\n          parseGraphQLSchema,\n          originalFields: args.fields,\n          req: { config, auth, info },\n        });\n\n        const { sessionToken, objectId, authDataResponse } = await objectsMutations.createObject(\n          '_User',\n          parseFields,\n          config,\n          auth,\n          info\n        );\n\n        context.info.sessionToken = sessionToken;\n        const viewer = await getUserFromSessionToken(\n          context,\n          mutationInfo,\n          'viewer.user.',\n          objectId\n        );\n        if (authDataResponse && viewer.user) { viewer.user.authDataResponse = authDataResponse; }\n        return {\n          viewer,\n        };\n      } catch (e) {\n        parseGraphQLSchema.handleError(e);\n      }\n    },\n  });\n\n  parseGraphQLSchema.addGraphQLType(signUpMutation.args.input.type.ofType, true, true);\n  parseGraphQLSchema.addGraphQLType(signUpMutation.type, true, true);\n  parseGraphQLSchema.addGraphQLMutation('signUp', signUpMutation, true, true);\n  const logInWithMutation = mutationWithClientMutationId({\n    name: 'LogInWith',\n    description:\n      'The logInWith mutation can be used to signup, login user with 3rd party authentication system. This mutation create a user if the authData do not correspond to an existing one.',\n    inputFields: {\n      authData: {\n        descriptions: 'This is the auth data of your custom auth provider',\n        type: new GraphQLNonNull(OBJECT),\n      },\n      fields: {\n        descriptions: 'These are the fields of the user to be created/updated and logged in.',\n        type: new GraphQLInputObjectType({\n          name: 'UserLoginWithInput',\n          fields: () => {\n            const classGraphQLCreateFields = parseGraphQLSchema.parseClassTypes[\n              '_User'\n            ].classGraphQLCreateType.getFields();\n            return Object.keys(classGraphQLCreateFields).reduce((fields, fieldName) => {\n              if (\n                fieldName !== 'password' &&\n                fieldName !== 'username' &&\n                fieldName !== 'authData'\n              ) {\n                fields[fieldName] = classGraphQLCreateFields[fieldName];\n              }\n              return fields;\n            }, {});\n          },\n        }),\n      },\n    },\n    outputFields: {\n      viewer: {\n        description: 'This is the new user that was created, signed up and returned as a viewer.',\n        type: new GraphQLNonNull(parseGraphQLSchema.viewerType),\n      },\n    },\n    mutateAndGetPayload: async (args, context, mutationInfo) => {\n      try {\n        const { fields, authData } = deepcopy(args);\n        const { config, auth, info } = context;\n\n        const parseFields = await transformTypes('create', fields, {\n          className: '_User',\n          parseGraphQLSchema,\n          originalFields: args.fields,\n          req: { config, auth, info },\n        });\n\n        const { sessionToken, objectId, authDataResponse } = await objectsMutations.createObject(\n          '_User',\n          { ...parseFields, authData },\n          config,\n          auth,\n          info\n        );\n\n        context.info.sessionToken = sessionToken;\n        const viewer = await getUserFromSessionToken(\n          context,\n          mutationInfo,\n          'viewer.user.',\n          objectId\n        );\n        if (authDataResponse && viewer.user) { viewer.user.authDataResponse = authDataResponse; }\n        return {\n          viewer,\n        };\n      } catch (e) {\n        parseGraphQLSchema.handleError(e);\n      }\n    },\n  });\n\n  parseGraphQLSchema.addGraphQLType(logInWithMutation.args.input.type.ofType, true, true);\n  parseGraphQLSchema.addGraphQLType(logInWithMutation.type, true, true);\n  parseGraphQLSchema.addGraphQLMutation('logInWith', logInWithMutation, true, true);\n\n  const logInMutation = mutationWithClientMutationId({\n    name: 'LogIn',\n    description: 'The logIn mutation can be used to log in an existing user.',\n    inputFields: {\n      username: {\n        description: 'This is the username used to log in the user.',\n        type: new GraphQLNonNull(GraphQLString),\n      },\n      password: {\n        description: 'This is the password used to log in the user.',\n        type: new GraphQLNonNull(GraphQLString),\n      },\n      authData: {\n        description: 'Auth data payload, needed if some required auth adapters are configured.',\n        type: OBJECT,\n      },\n    },\n    outputFields: {\n      viewer: {\n        description: 'This is the existing user that was logged in and returned as a viewer.',\n        type: new GraphQLNonNull(parseGraphQLSchema.viewerType),\n      },\n    },\n    mutateAndGetPayload: async (args, context, mutationInfo) => {\n      try {\n        const { username, password, authData } = deepcopy(args);\n        const { config, auth, info } = context;\n\n        const { sessionToken, objectId, authDataResponse } = (\n          await usersRouter.handleLogIn({\n            body: {\n              username,\n              password,\n              authData,\n            },\n            query: {},\n            config,\n            auth,\n            info,\n          })\n        ).response;\n\n        context.info.sessionToken = sessionToken;\n\n        const viewer = await getUserFromSessionToken(\n          context,\n          mutationInfo,\n          'viewer.user.',\n          objectId\n        );\n        if (authDataResponse && viewer.user) { viewer.user.authDataResponse = authDataResponse; }\n        return {\n          viewer,\n        };\n      } catch (e) {\n        parseGraphQLSchema.handleError(e);\n      }\n    },\n  });\n\n  parseGraphQLSchema.addGraphQLType(logInMutation.args.input.type.ofType, true, true);\n  parseGraphQLSchema.addGraphQLType(logInMutation.type, true, true);\n  parseGraphQLSchema.addGraphQLMutation('logIn', logInMutation, true, true);\n\n  const logOutMutation = mutationWithClientMutationId({\n    name: 'LogOut',\n    description: 'The logOut mutation can be used to log out an existing user.',\n    outputFields: {\n      ok: {\n        description: \"It's always true.\",\n        type: new GraphQLNonNull(GraphQLBoolean),\n      },\n    },\n    mutateAndGetPayload: async (_args, context) => {\n      try {\n        const { config, auth, info } = context;\n\n        await usersRouter.handleLogOut({\n          config,\n          auth,\n          info,\n        });\n\n        return { ok: true };\n      } catch (e) {\n        parseGraphQLSchema.handleError(e);\n      }\n    },\n  });\n\n  parseGraphQLSchema.addGraphQLType(logOutMutation.args.input.type.ofType, true, true);\n  parseGraphQLSchema.addGraphQLType(logOutMutation.type, true, true);\n  parseGraphQLSchema.addGraphQLMutation('logOut', logOutMutation, true, true);\n\n  const resetPasswordMutation = mutationWithClientMutationId({\n    name: 'ResetPassword',\n    description:\n      'The resetPassword mutation can be used to reset the password of an existing user.',\n    inputFields: {\n      email: {\n        descriptions: 'Email of the user that should receive the reset email',\n        type: new GraphQLNonNull(GraphQLString),\n      },\n    },\n    outputFields: {\n      ok: {\n        description: \"It's always true.\",\n        type: new GraphQLNonNull(GraphQLBoolean),\n      },\n    },\n    mutateAndGetPayload: async ({ email }, context) => {\n      const { config, auth, info } = context;\n\n      await usersRouter.handleResetRequest({\n        body: {\n          email,\n        },\n        config,\n        auth,\n        info,\n      });\n\n      return { ok: true };\n    },\n  });\n\n  parseGraphQLSchema.addGraphQLType(resetPasswordMutation.args.input.type.ofType, true, true);\n  parseGraphQLSchema.addGraphQLType(resetPasswordMutation.type, true, true);\n  parseGraphQLSchema.addGraphQLMutation('resetPassword', resetPasswordMutation, true, true);\n\n  const confirmResetPasswordMutation = mutationWithClientMutationId({\n    name: 'ConfirmResetPassword',\n    description:\n      'The confirmResetPassword mutation can be used to reset the password of an existing user.',\n    inputFields: {\n      username: {\n        descriptions: 'Username of the user that have received the reset email',\n        type: new GraphQLNonNull(GraphQLString),\n      },\n      password: {\n        descriptions: 'New password of the user',\n        type: new GraphQLNonNull(GraphQLString),\n      },\n      token: {\n        descriptions: 'Reset token that was emailed to the user',\n        type: new GraphQLNonNull(GraphQLString),\n      },\n    },\n    outputFields: {\n      ok: {\n        description: \"It's always true.\",\n        type: new GraphQLNonNull(GraphQLBoolean),\n      },\n    },\n    mutateAndGetPayload: async ({ password, token }, context) => {\n      const { config } = context;\n      if (!password) {\n        throw new Parse.Error(Parse.Error.PASSWORD_MISSING, 'you must provide a password');\n      }\n      if (!token) {\n        throw new Parse.Error(Parse.Error.OTHER_CAUSE, 'you must provide a token');\n      }\n\n      const userController = config.userController;\n      await userController.updatePassword(token, password);\n      return { ok: true };\n    },\n  });\n\n  parseGraphQLSchema.addGraphQLType(\n    confirmResetPasswordMutation.args.input.type.ofType,\n    true,\n    true\n  );\n  parseGraphQLSchema.addGraphQLType(confirmResetPasswordMutation.type, true, true);\n  parseGraphQLSchema.addGraphQLMutation(\n    'confirmResetPassword',\n    confirmResetPasswordMutation,\n    true,\n    true\n  );\n\n  const sendVerificationEmailMutation = mutationWithClientMutationId({\n    name: 'SendVerificationEmail',\n    description:\n      'The sendVerificationEmail mutation can be used to send the verification email again.',\n    inputFields: {\n      email: {\n        descriptions: 'Email of the user that should receive the verification email',\n        type: new GraphQLNonNull(GraphQLString),\n      },\n    },\n    outputFields: {\n      ok: {\n        description: \"It's always true.\",\n        type: new GraphQLNonNull(GraphQLBoolean),\n      },\n    },\n    mutateAndGetPayload: async ({ email }, context) => {\n      try {\n        const { config, auth, info } = context;\n\n        await usersRouter.handleVerificationEmailRequest({\n          body: {\n            email,\n          },\n          config,\n          auth,\n          info,\n        });\n\n        return { ok: true };\n      } catch (e) {\n        parseGraphQLSchema.handleError(e);\n      }\n    },\n  });\n\n  parseGraphQLSchema.addGraphQLType(\n    sendVerificationEmailMutation.args.input.type.ofType,\n    true,\n    true\n  );\n  parseGraphQLSchema.addGraphQLType(sendVerificationEmailMutation.type, true, true);\n  parseGraphQLSchema.addGraphQLMutation(\n    'sendVerificationEmail',\n    sendVerificationEmailMutation,\n    true,\n    true\n  );\n\n  const challengeMutation = mutationWithClientMutationId({\n    name: 'Challenge',\n    description:\n      'The challenge mutation can be used to initiate an authentication challenge when an auth adapter needs it.',\n    inputFields: {\n      username: {\n        description: 'This is the username used to log in the user.',\n        type: GraphQLString,\n      },\n      password: {\n        description: 'This is the password used to log in the user.',\n        type: GraphQLString,\n      },\n      authData: {\n        description:\n          'Auth data allow to preidentify the user if the auth adapter needs preidentification.',\n        type: OBJECT,\n      },\n      challengeData: {\n        description:\n          'Challenge data payload, can be used to post data to auth providers to auth providers if they need data for the response.',\n        type: OBJECT,\n      },\n    },\n    outputFields: {\n      challengeData: {\n        description: 'Challenge response from configured auth adapters.',\n        type: OBJECT,\n      },\n    },\n    mutateAndGetPayload: async (input, context) => {\n      try {\n        const { config, auth, info } = context;\n\n        const { response } = await usersRouter.handleChallenge({\n          body: input,\n          config,\n          auth,\n          info,\n        });\n        return response;\n      } catch (e) {\n        parseGraphQLSchema.handleError(e);\n      }\n    },\n  });\n\n  parseGraphQLSchema.addGraphQLType(challengeMutation.args.input.type.ofType, true, true);\n  parseGraphQLSchema.addGraphQLType(challengeMutation.type, true, true);\n  parseGraphQLSchema.addGraphQLMutation('challenge', challengeMutation, true, true);\n};\n\nexport { load };\n"],"mappings":"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","ignoreList":[]}
|