parse-server 8.0.0-alpha.9 → 8.0.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +1 -3
- package/lib/Adapters/AdapterLoader.js +1 -2
- package/lib/Adapters/Cache/RedisCacheAdapter.js +2 -2
- package/lib/Adapters/PubSub/RedisPubSub.js +22 -3
- package/lib/Adapters/Storage/Postgres/PostgresStorageAdapter.js +4 -4
- package/lib/Config.js +19 -1
- package/lib/Controllers/AnalyticsController.js +3 -3
- package/lib/Controllers/UserController.js +43 -48
- package/lib/GraphQL/helpers/objectsQueries.js +2 -1
- package/lib/GraphQL/loaders/usersMutations.js +2 -6
- package/lib/Options/Definitions.js +6 -1
- package/lib/Options/docs.js +3 -2
- package/lib/Options/index.js +1 -1
- package/lib/ParseServer.js +10 -5
- package/lib/PromiseRouter.js +2 -2
- package/lib/Routers/AggregateRouter.js +2 -2
- package/lib/Routers/AudiencesRouter.js +2 -2
- package/lib/Routers/ClassesRouter.js +5 -5
- package/lib/Routers/CloudCodeRouter.js +3 -3
- package/lib/Routers/FilesRouter.js +2 -3
- package/lib/Routers/FunctionsRouter.js +2 -2
- package/lib/Routers/GlobalConfigRouter.js +3 -3
- package/lib/Routers/GraphQLRouter.js +2 -2
- package/lib/Routers/HooksRouter.js +5 -5
- package/lib/Routers/IAPValidationRouter.js +4 -4
- package/lib/Routers/InstallationsRouter.js +2 -2
- package/lib/Routers/PagesRouter.js +22 -36
- package/lib/Routers/PublicAPIRouter.js +26 -32
- package/lib/Routers/PushRouter.js +2 -2
- package/lib/Routers/SchemasRouter.js +6 -6
- package/lib/Routers/UsersRouter.js +20 -10
- package/lib/SchemaMigrations/DefinedSchemas.js +3 -3
- package/lib/batch.js +5 -5
- package/lib/middlewares.js +29 -6
- package/lib/vendor/mongodbUrl.js +2 -2
- package/package.json +15 -17
- 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":[]}
|
|
@@ -38,6 +38,7 @@ const getObject = async (className, objectId, keys, include, readPreference, inc
|
|
|
38
38
|
options.keys = keys;
|
|
39
39
|
}
|
|
40
40
|
} catch (e) {
|
|
41
|
+
// eslint-disable-next-line no-console
|
|
41
42
|
console.error(e);
|
|
42
43
|
}
|
|
43
44
|
if (include) {
|
|
@@ -242,4 +243,4 @@ const calculateSkipAndLimit = (skipInput, first, after, last, before, maxLimit)
|
|
|
242
243
|
};
|
|
243
244
|
};
|
|
244
245
|
exports.calculateSkipAndLimit = calculateSkipAndLimit;
|
|
245
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_node","_interopRequireDefault","require","_graphqlRelay","_rest","_query","e","__esModule","default","needToGetAllKeys","fields","keys","parseClasses","split","some","keyName","key","type","subClass","targetClass","exports","getObject","className","objectId","include","readPreference","includeReadPreference","config","auth","info","options","console","error","response","rest","get","clientSDK","context","results","length","Parse","Error","OBJECT_NOT_FOUND","object","sessionToken","findObjects","where","order","skipInput","first","after","last","before","includeAll","subqueryReadPreference","selectedFields","transformQueryInputToParse","skipAndLimitCalculation","calculateSkipAndLimit","maxLimit","skip","limit","needToPreCount","preCount","undefined","preCountOptions","count","Object","find","field","startsWith","includes","findResult","edges","pageInfo","map","result","index","cursor","offsetToCursor","node","hasPreviousPage","startCursor","endCursor","hasNextPage","INVALID_QUERY","cursorToOffset"],"sources":["../../../src/GraphQL/helpers/objectsQueries.js"],"sourcesContent":["import Parse from 'parse/node';\nimport { offsetToCursor, cursorToOffset } from 'graphql-relay';\nimport rest from '../../rest';\nimport { transformQueryInputToParse } from '../transformers/query';\n\n// Eslint/Prettier conflict\n/* eslint-disable*/\nconst needToGetAllKeys = (fields, keys, parseClasses) =>\n  keys\n    ? keys.split(',').some(keyName => {\n        const key = keyName.split('.');\n        if (fields[key[0]]) {\n          if (fields[key[0]].type === 'Relation') return false;\n          if (fields[key[0]].type === 'Pointer') {\n            const subClass = parseClasses[fields[key[0]].targetClass];\n            if (subClass && subClass.fields[key[1]]) {\n              // Current sub key is not custom\n              return false;\n            }\n          } else if (\n            !key[1] ||\n            fields[key[0]].type === 'Array' ||\n            fields[key[0]].type === 'Object'\n          ) {\n            // current key is not custom\n            return false;\n          }\n        }\n        // Key not found into Parse Schema so it's custom\n        return true;\n      })\n    : true;\n/* eslint-enable*/\n\nconst getObject = async (\n  className,\n  objectId,\n  keys,\n  include,\n  readPreference,\n  includeReadPreference,\n  config,\n  auth,\n  info,\n  parseClasses\n) => {\n  const options = {};\n  try {\n    if (!needToGetAllKeys(parseClasses[className].fields, keys, parseClasses)) {\n      options.keys = keys;\n    }\n  } catch (e) {\n    console.error(e);\n  }\n  if (include) {\n    options.include = include;\n    if (includeReadPreference) {\n      options.includeReadPreference = includeReadPreference;\n    }\n  }\n  if (readPreference) {\n    options.readPreference = readPreference;\n  }\n\n  const response = await rest.get(\n    config,\n    auth,\n    className,\n    objectId,\n    options,\n    info.clientSDK,\n    info.context\n  );\n\n  if (!response.results || response.results.length == 0) {\n    throw new Parse.Error(Parse.Error.OBJECT_NOT_FOUND, 'Object not found.');\n  }\n\n  const object = response.results[0];\n  if (className === '_User') {\n    delete object.sessionToken;\n  }\n  return object;\n};\n\nconst findObjects = async (\n  className,\n  where,\n  order,\n  skipInput,\n  first,\n  after,\n  last,\n  before,\n  keys,\n  include,\n  includeAll,\n  readPreference,\n  includeReadPreference,\n  subqueryReadPreference,\n  config,\n  auth,\n  info,\n  selectedFields,\n  parseClasses\n) => {\n  if (!where) {\n    where = {};\n  }\n  transformQueryInputToParse(where, className, parseClasses);\n  const skipAndLimitCalculation = calculateSkipAndLimit(\n    skipInput,\n    first,\n    after,\n    last,\n    before,\n    config.maxLimit\n  );\n  let { skip } = skipAndLimitCalculation;\n  const { limit, needToPreCount } = skipAndLimitCalculation;\n  let preCount = undefined;\n  if (needToPreCount) {\n    const preCountOptions = {\n      limit: 0,\n      count: true,\n    };\n    if (readPreference) {\n      preCountOptions.readPreference = readPreference;\n    }\n    if (Object.keys(where).length > 0 && subqueryReadPreference) {\n      preCountOptions.subqueryReadPreference = subqueryReadPreference;\n    }\n    preCount = (\n      await rest.find(config, auth, className, where, preCountOptions, info.clientSDK, info.context)\n    ).count;\n    if ((skip || 0) + limit < preCount) {\n      skip = preCount - limit;\n    }\n  }\n\n  const options = {};\n\n  if (selectedFields.find(field => field.startsWith('edges.') || field.startsWith('pageInfo.'))) {\n    if (limit || limit === 0) {\n      options.limit = limit;\n    } else {\n      options.limit = 100;\n    }\n    if (options.limit !== 0) {\n      if (order) {\n        options.order = order;\n      }\n      if (skip) {\n        options.skip = skip;\n      }\n      if (config.maxLimit && options.limit > config.maxLimit) {\n        // Silently replace the limit on the query with the max configured\n        options.limit = config.maxLimit;\n      }\n      if (!needToGetAllKeys(parseClasses[className].fields, keys, parseClasses)) {\n        options.keys = keys;\n      }\n      if (includeAll === true) {\n        options.includeAll = includeAll;\n      }\n      if (!options.includeAll && include) {\n        options.include = include;\n      }\n      if ((options.includeAll || options.include) && includeReadPreference) {\n        options.includeReadPreference = includeReadPreference;\n      }\n    }\n  } else {\n    options.limit = 0;\n  }\n\n  if (\n    (selectedFields.includes('count') ||\n      selectedFields.includes('pageInfo.hasPreviousPage') ||\n      selectedFields.includes('pageInfo.hasNextPage')) &&\n    !needToPreCount\n  ) {\n    options.count = true;\n  }\n\n  if (readPreference) {\n    options.readPreference = readPreference;\n  }\n  if (Object.keys(where).length > 0 && subqueryReadPreference) {\n    options.subqueryReadPreference = subqueryReadPreference;\n  }\n\n  let results, count;\n  if (options.count || !options.limit || (options.limit && options.limit > 0)) {\n    const findResult = await rest.find(\n      config,\n      auth,\n      className,\n      where,\n      options,\n      info.clientSDK,\n      info.context\n    );\n    results = findResult.results;\n    count = findResult.count;\n  }\n\n  let edges = null;\n  let pageInfo = null;\n  if (results) {\n    edges = results.map((result, index) => ({\n      cursor: offsetToCursor((skip || 0) + index),\n      node: result,\n    }));\n\n    pageInfo = {\n      hasPreviousPage:\n        ((preCount && preCount > 0) || (count && count > 0)) && skip !== undefined && skip > 0,\n      startCursor: offsetToCursor(skip || 0),\n      endCursor: offsetToCursor((skip || 0) + (results.length || 1) - 1),\n      hasNextPage: (preCount || count) > (skip || 0) + results.length,\n    };\n  }\n\n  return {\n    edges,\n    pageInfo,\n    count: preCount || count,\n  };\n};\n\nconst calculateSkipAndLimit = (skipInput, first, after, last, before, maxLimit) => {\n  let skip = undefined;\n  let limit = undefined;\n  let needToPreCount = false;\n\n  // Validates the skip input\n  if (skipInput || skipInput === 0) {\n    if (skipInput < 0) {\n      throw new Parse.Error(Parse.Error.INVALID_QUERY, 'Skip should be a positive number');\n    }\n    skip = skipInput;\n  }\n\n  // Validates the after param\n  if (after) {\n    after = cursorToOffset(after);\n    if ((!after && after !== 0) || after < 0) {\n      throw new Parse.Error(Parse.Error.INVALID_QUERY, 'After is not a valid cursor');\n    }\n\n    // If skip and after are passed, a new skip is calculated by adding them\n    skip = (skip || 0) + (after + 1);\n  }\n\n  // Validates the first param\n  if (first || first === 0) {\n    if (first < 0) {\n      throw new Parse.Error(Parse.Error.INVALID_QUERY, 'First should be a positive number');\n    }\n\n    // The first param is translated to the limit param of the Parse legacy API\n    limit = first;\n  }\n\n  // Validates the before param\n  if (before || before === 0) {\n    // This method converts the cursor to the index of the object\n    before = cursorToOffset(before);\n    if ((!before && before !== 0) || before < 0) {\n      throw new Parse.Error(Parse.Error.INVALID_QUERY, 'Before is not a valid cursor');\n    }\n\n    if ((skip || 0) >= before) {\n      // If the before index is less than the skip, no objects will be returned\n      limit = 0;\n    } else if ((!limit && limit !== 0) || (skip || 0) + limit > before) {\n      // If there is no limit set, the limit is calculated. Or, if the limit (plus skip) is bigger than the before index, the new limit is set.\n      limit = before - (skip || 0);\n    }\n  }\n\n  // Validates the last param\n  if (last || last === 0) {\n    if (last < 0) {\n      throw new Parse.Error(Parse.Error.INVALID_QUERY, 'Last should be a positive number');\n    }\n\n    if (last > maxLimit) {\n      // Last can't be bigger than Parse server maxLimit config.\n      last = maxLimit;\n    }\n\n    if (limit || limit === 0) {\n      // If there is a previous limit set, it may be adjusted\n      if (last < limit) {\n        // if last is less than the current limit\n        skip = (skip || 0) + (limit - last); // The skip is adjusted\n        limit = last; // the limit is adjusted\n      }\n    } else if (last === 0) {\n      // No objects will be returned\n      limit = 0;\n    } else {\n      // No previous limit set, the limit will be equal to last and pre count is needed.\n      limit = last;\n      needToPreCount = true;\n    }\n  }\n  return {\n    skip,\n    limit,\n    needToPreCount,\n  };\n};\n\nexport { getObject, findObjects, calculateSkipAndLimit, needToGetAllKeys };\n"],"mappings":"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","ignoreList":[]}
|
|
246
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_node","_interopRequireDefault","require","_graphqlRelay","_rest","_query","e","__esModule","default","needToGetAllKeys","fields","keys","parseClasses","split","some","keyName","key","type","subClass","targetClass","exports","getObject","className","objectId","include","readPreference","includeReadPreference","config","auth","info","options","console","error","response","rest","get","clientSDK","context","results","length","Parse","Error","OBJECT_NOT_FOUND","object","sessionToken","findObjects","where","order","skipInput","first","after","last","before","includeAll","subqueryReadPreference","selectedFields","transformQueryInputToParse","skipAndLimitCalculation","calculateSkipAndLimit","maxLimit","skip","limit","needToPreCount","preCount","undefined","preCountOptions","count","Object","find","field","startsWith","includes","findResult","edges","pageInfo","map","result","index","cursor","offsetToCursor","node","hasPreviousPage","startCursor","endCursor","hasNextPage","INVALID_QUERY","cursorToOffset"],"sources":["../../../src/GraphQL/helpers/objectsQueries.js"],"sourcesContent":["import Parse from 'parse/node';\nimport { offsetToCursor, cursorToOffset } from 'graphql-relay';\nimport rest from '../../rest';\nimport { transformQueryInputToParse } from '../transformers/query';\n\n// Eslint/Prettier conflict\n/* eslint-disable*/\nconst needToGetAllKeys = (fields, keys, parseClasses) =>\n  keys\n    ? keys.split(',').some(keyName => {\n        const key = keyName.split('.');\n        if (fields[key[0]]) {\n          if (fields[key[0]].type === 'Relation') return false;\n          if (fields[key[0]].type === 'Pointer') {\n            const subClass = parseClasses[fields[key[0]].targetClass];\n            if (subClass && subClass.fields[key[1]]) {\n              // Current sub key is not custom\n              return false;\n            }\n          } else if (\n            !key[1] ||\n            fields[key[0]].type === 'Array' ||\n            fields[key[0]].type === 'Object'\n          ) {\n            // current key is not custom\n            return false;\n          }\n        }\n        // Key not found into Parse Schema so it's custom\n        return true;\n      })\n    : true;\n/* eslint-enable*/\n\nconst getObject = async (\n  className,\n  objectId,\n  keys,\n  include,\n  readPreference,\n  includeReadPreference,\n  config,\n  auth,\n  info,\n  parseClasses\n) => {\n  const options = {};\n  try {\n    if (!needToGetAllKeys(parseClasses[className].fields, keys, parseClasses)) {\n      options.keys = keys;\n    }\n  } catch (e) {\n    // eslint-disable-next-line no-console\n    console.error(e);\n  }\n  if (include) {\n    options.include = include;\n    if (includeReadPreference) {\n      options.includeReadPreference = includeReadPreference;\n    }\n  }\n  if (readPreference) {\n    options.readPreference = readPreference;\n  }\n\n  const response = await rest.get(\n    config,\n    auth,\n    className,\n    objectId,\n    options,\n    info.clientSDK,\n    info.context\n  );\n\n  if (!response.results || response.results.length == 0) {\n    throw new Parse.Error(Parse.Error.OBJECT_NOT_FOUND, 'Object not found.');\n  }\n\n  const object = response.results[0];\n  if (className === '_User') {\n    delete object.sessionToken;\n  }\n  return object;\n};\n\nconst findObjects = async (\n  className,\n  where,\n  order,\n  skipInput,\n  first,\n  after,\n  last,\n  before,\n  keys,\n  include,\n  includeAll,\n  readPreference,\n  includeReadPreference,\n  subqueryReadPreference,\n  config,\n  auth,\n  info,\n  selectedFields,\n  parseClasses\n) => {\n  if (!where) {\n    where = {};\n  }\n  transformQueryInputToParse(where, className, parseClasses);\n  const skipAndLimitCalculation = calculateSkipAndLimit(\n    skipInput,\n    first,\n    after,\n    last,\n    before,\n    config.maxLimit\n  );\n  let { skip } = skipAndLimitCalculation;\n  const { limit, needToPreCount } = skipAndLimitCalculation;\n  let preCount = undefined;\n  if (needToPreCount) {\n    const preCountOptions = {\n      limit: 0,\n      count: true,\n    };\n    if (readPreference) {\n      preCountOptions.readPreference = readPreference;\n    }\n    if (Object.keys(where).length > 0 && subqueryReadPreference) {\n      preCountOptions.subqueryReadPreference = subqueryReadPreference;\n    }\n    preCount = (\n      await rest.find(config, auth, className, where, preCountOptions, info.clientSDK, info.context)\n    ).count;\n    if ((skip || 0) + limit < preCount) {\n      skip = preCount - limit;\n    }\n  }\n\n  const options = {};\n\n  if (selectedFields.find(field => field.startsWith('edges.') || field.startsWith('pageInfo.'))) {\n    if (limit || limit === 0) {\n      options.limit = limit;\n    } else {\n      options.limit = 100;\n    }\n    if (options.limit !== 0) {\n      if (order) {\n        options.order = order;\n      }\n      if (skip) {\n        options.skip = skip;\n      }\n      if (config.maxLimit && options.limit > config.maxLimit) {\n        // Silently replace the limit on the query with the max configured\n        options.limit = config.maxLimit;\n      }\n      if (!needToGetAllKeys(parseClasses[className].fields, keys, parseClasses)) {\n        options.keys = keys;\n      }\n      if (includeAll === true) {\n        options.includeAll = includeAll;\n      }\n      if (!options.includeAll && include) {\n        options.include = include;\n      }\n      if ((options.includeAll || options.include) && includeReadPreference) {\n        options.includeReadPreference = includeReadPreference;\n      }\n    }\n  } else {\n    options.limit = 0;\n  }\n\n  if (\n    (selectedFields.includes('count') ||\n      selectedFields.includes('pageInfo.hasPreviousPage') ||\n      selectedFields.includes('pageInfo.hasNextPage')) &&\n    !needToPreCount\n  ) {\n    options.count = true;\n  }\n\n  if (readPreference) {\n    options.readPreference = readPreference;\n  }\n  if (Object.keys(where).length > 0 && subqueryReadPreference) {\n    options.subqueryReadPreference = subqueryReadPreference;\n  }\n\n  let results, count;\n  if (options.count || !options.limit || (options.limit && options.limit > 0)) {\n    const findResult = await rest.find(\n      config,\n      auth,\n      className,\n      where,\n      options,\n      info.clientSDK,\n      info.context\n    );\n    results = findResult.results;\n    count = findResult.count;\n  }\n\n  let edges = null;\n  let pageInfo = null;\n  if (results) {\n    edges = results.map((result, index) => ({\n      cursor: offsetToCursor((skip || 0) + index),\n      node: result,\n    }));\n\n    pageInfo = {\n      hasPreviousPage:\n        ((preCount && preCount > 0) || (count && count > 0)) && skip !== undefined && skip > 0,\n      startCursor: offsetToCursor(skip || 0),\n      endCursor: offsetToCursor((skip || 0) + (results.length || 1) - 1),\n      hasNextPage: (preCount || count) > (skip || 0) + results.length,\n    };\n  }\n\n  return {\n    edges,\n    pageInfo,\n    count: preCount || count,\n  };\n};\n\nconst calculateSkipAndLimit = (skipInput, first, after, last, before, maxLimit) => {\n  let skip = undefined;\n  let limit = undefined;\n  let needToPreCount = false;\n\n  // Validates the skip input\n  if (skipInput || skipInput === 0) {\n    if (skipInput < 0) {\n      throw new Parse.Error(Parse.Error.INVALID_QUERY, 'Skip should be a positive number');\n    }\n    skip = skipInput;\n  }\n\n  // Validates the after param\n  if (after) {\n    after = cursorToOffset(after);\n    if ((!after && after !== 0) || after < 0) {\n      throw new Parse.Error(Parse.Error.INVALID_QUERY, 'After is not a valid cursor');\n    }\n\n    // If skip and after are passed, a new skip is calculated by adding them\n    skip = (skip || 0) + (after + 1);\n  }\n\n  // Validates the first param\n  if (first || first === 0) {\n    if (first < 0) {\n      throw new Parse.Error(Parse.Error.INVALID_QUERY, 'First should be a positive number');\n    }\n\n    // The first param is translated to the limit param of the Parse legacy API\n    limit = first;\n  }\n\n  // Validates the before param\n  if (before || before === 0) {\n    // This method converts the cursor to the index of the object\n    before = cursorToOffset(before);\n    if ((!before && before !== 0) || before < 0) {\n      throw new Parse.Error(Parse.Error.INVALID_QUERY, 'Before is not a valid cursor');\n    }\n\n    if ((skip || 0) >= before) {\n      // If the before index is less than the skip, no objects will be returned\n      limit = 0;\n    } else if ((!limit && limit !== 0) || (skip || 0) + limit > before) {\n      // If there is no limit set, the limit is calculated. Or, if the limit (plus skip) is bigger than the before index, the new limit is set.\n      limit = before - (skip || 0);\n    }\n  }\n\n  // Validates the last param\n  if (last || last === 0) {\n    if (last < 0) {\n      throw new Parse.Error(Parse.Error.INVALID_QUERY, 'Last should be a positive number');\n    }\n\n    if (last > maxLimit) {\n      // Last can't be bigger than Parse server maxLimit config.\n      last = maxLimit;\n    }\n\n    if (limit || limit === 0) {\n      // If there is a previous limit set, it may be adjusted\n      if (last < limit) {\n        // if last is less than the current limit\n        skip = (skip || 0) + (limit - last); // The skip is adjusted\n        limit = last; // the limit is adjusted\n      }\n    } else if (last === 0) {\n      // No objects will be returned\n      limit = 0;\n    } else {\n      // No previous limit set, the limit will be equal to last and pre count is needed.\n      limit = last;\n      needToPreCount = true;\n    }\n  }\n  return {\n    skip,\n    limit,\n    needToPreCount,\n  };\n};\n\nexport { getObject, findObjects, calculateSkipAndLimit, needToGetAllKeys };\n"],"mappings":"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","ignoreList":[]}
|