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

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -33,7 +33,7 @@ class RedisCacheAdapter {
33
33
  if (this.client.isOpen) {
34
34
  return;
35
35
  }
36
- return this.client.connect();
36
+ return await this.client.connect();
37
37
  }
38
38
  async handleShutdown() {
39
39
  if (!this.client) {
@@ -106,4 +106,4 @@ class RedisCacheAdapter {
106
106
  }
107
107
  exports.RedisCacheAdapter = RedisCacheAdapter;
108
108
  var _default = exports.default = RedisCacheAdapter;
109
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_redis","require","_logger","_interopRequireDefault","_KeyPromiseQueue","e","__esModule","default","DEFAULT_REDIS_TTL","FLUSH_DB_KEY","debug","args","message","arguments","concat","slice","length","logger","apply","isValidTTL","ttl","RedisCacheAdapter","constructor","redisCtx","client","createClient","queue","KeyPromiseQueue","on","err","error","connect","isOpen","handleShutdown","quit","get","key","enqueue","res","JSON","parse","put","value","stringify","Infinity","set","PX","del","clear","sendCommand","getAllKeys","keys","exports","_default"],"sources":["../../../src/Adapters/Cache/RedisCacheAdapter.js"],"sourcesContent":["import { createClient } from 'redis';\nimport logger from '../../logger';\nimport { KeyPromiseQueue } from '../../KeyPromiseQueue';\n\nconst DEFAULT_REDIS_TTL = 30 * 1000; // 30 seconds in milliseconds\nconst FLUSH_DB_KEY = '__flush_db__';\n\nfunction debug(...args: any) {\n  const message = ['RedisCacheAdapter: ' + arguments[0]].concat(args.slice(1, args.length));\n  logger.debug.apply(logger, message);\n}\n\nconst isValidTTL = ttl => typeof ttl === 'number' && ttl > 0;\n\nexport class RedisCacheAdapter {\n  constructor(redisCtx, ttl = DEFAULT_REDIS_TTL) {\n    this.ttl = isValidTTL(ttl) ? ttl : DEFAULT_REDIS_TTL;\n    this.client = createClient(redisCtx);\n    this.queue = new KeyPromiseQueue();\n    this.client.on('error', err => { logger.error('RedisCacheAdapter client error', { error: err }) });\n    this.client.on('connect', () => {});\n    this.client.on('reconnecting', () => {});\n    this.client.on('ready', () => {});\n  }\n\n  async connect() {\n    if (this.client.isOpen) {\n      return;\n    }\n    return this.client.connect();\n  }\n\n  async handleShutdown() {\n    if (!this.client) {\n      return;\n    }\n    try {\n      await this.client.quit();\n    } catch (err) {\n      logger.error('RedisCacheAdapter error on shutdown', { error: err });\n    }\n  }\n\n  async get(key) {\n    debug('get', { key });\n    try {\n      await this.queue.enqueue(key);\n      const res = await this.client.get(key);\n      if (!res) {\n        return null;\n      }\n      return JSON.parse(res);\n    } catch (err) {\n      logger.error('RedisCacheAdapter error on get', { error: err });\n    }\n  }\n\n  async put(key, value, ttl = this.ttl) {\n    value = JSON.stringify(value);\n    debug('put', { key, value, ttl });\n    await this.queue.enqueue(key);\n    if (ttl === 0) {\n      // ttl of zero is a logical no-op, but redis cannot set expire time of zero\n      return;\n    }\n\n    if (ttl === Infinity) {\n      return this.client.set(key, value);\n    }\n\n    if (!isValidTTL(ttl)) {\n      ttl = this.ttl;\n    }\n    return this.client.set(key, value, { PX: ttl });\n  }\n\n  async del(key) {\n    debug('del', { key });\n    await this.queue.enqueue(key);\n    return this.client.del(key);\n  }\n\n  async clear() {\n    debug('clear');\n    await this.queue.enqueue(FLUSH_DB_KEY);\n    return this.client.sendCommand(['FLUSHDB']);\n  }\n\n  // Used for testing\n  getAllKeys() {\n    return this.client.keys('*');\n  }\n}\n\nexport default RedisCacheAdapter;\n"],"mappings":"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","ignoreList":[]}
109
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_redis","require","_logger","_interopRequireDefault","_KeyPromiseQueue","e","__esModule","default","DEFAULT_REDIS_TTL","FLUSH_DB_KEY","debug","args","message","arguments","concat","slice","length","logger","apply","isValidTTL","ttl","RedisCacheAdapter","constructor","redisCtx","client","createClient","queue","KeyPromiseQueue","on","err","error","connect","isOpen","handleShutdown","quit","get","key","enqueue","res","JSON","parse","put","value","stringify","Infinity","set","PX","del","clear","sendCommand","getAllKeys","keys","exports","_default"],"sources":["../../../src/Adapters/Cache/RedisCacheAdapter.js"],"sourcesContent":["import { createClient } from 'redis';\nimport logger from '../../logger';\nimport { KeyPromiseQueue } from '../../KeyPromiseQueue';\n\nconst DEFAULT_REDIS_TTL = 30 * 1000; // 30 seconds in milliseconds\nconst FLUSH_DB_KEY = '__flush_db__';\n\nfunction debug(...args: any) {\n  const message = ['RedisCacheAdapter: ' + arguments[0]].concat(args.slice(1, args.length));\n  logger.debug.apply(logger, message);\n}\n\nconst isValidTTL = ttl => typeof ttl === 'number' && ttl > 0;\n\nexport class RedisCacheAdapter {\n  constructor(redisCtx, ttl = DEFAULT_REDIS_TTL) {\n    this.ttl = isValidTTL(ttl) ? ttl : DEFAULT_REDIS_TTL;\n    this.client = createClient(redisCtx);\n    this.queue = new KeyPromiseQueue();\n    this.client.on('error', err => { logger.error('RedisCacheAdapter client error', { error: err }) });\n    this.client.on('connect', () => {});\n    this.client.on('reconnecting', () => {});\n    this.client.on('ready', () => {});\n  }\n\n  async connect() {\n    if (this.client.isOpen) {\n      return;\n    }\n    return await this.client.connect();\n  }\n\n  async handleShutdown() {\n    if (!this.client) {\n      return;\n    }\n    try {\n      await this.client.quit();\n    } catch (err) {\n      logger.error('RedisCacheAdapter error on shutdown', { error: err });\n    }\n  }\n\n  async get(key) {\n    debug('get', { key });\n    try {\n      await this.queue.enqueue(key);\n      const res = await this.client.get(key);\n      if (!res) {\n        return null;\n      }\n      return JSON.parse(res);\n    } catch (err) {\n      logger.error('RedisCacheAdapter error on get', { error: err });\n    }\n  }\n\n  async put(key, value, ttl = this.ttl) {\n    value = JSON.stringify(value);\n    debug('put', { key, value, ttl });\n    await this.queue.enqueue(key);\n    if (ttl === 0) {\n      // ttl of zero is a logical no-op, but redis cannot set expire time of zero\n      return;\n    }\n\n    if (ttl === Infinity) {\n      return this.client.set(key, value);\n    }\n\n    if (!isValidTTL(ttl)) {\n      ttl = this.ttl;\n    }\n    return this.client.set(key, value, { PX: ttl });\n  }\n\n  async del(key) {\n    debug('del', { key });\n    await this.queue.enqueue(key);\n    return this.client.del(key);\n  }\n\n  async clear() {\n    debug('clear');\n    await this.queue.enqueue(FLUSH_DB_KEY);\n    return this.client.sendCommand(['FLUSHDB']);\n  }\n\n  // Used for testing\n  getAllKeys() {\n    return this.client.keys('*');\n  }\n}\n\nexport default RedisCacheAdapter;\n"],"mappings":"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","ignoreList":[]}
@@ -5,28 +5,47 @@ Object.defineProperty(exports, "__esModule", {
5
5
  });
6
6
  exports.RedisPubSub = void 0;
7
7
  var _redis = require("redis");
8
+ var _logger = require("../../logger");
8
9
  function createPublisher({
9
10
  redisURL,
10
11
  redisOptions = {}
11
12
  }) {
12
13
  redisOptions.no_ready_check = true;
13
- return (0, _redis.createClient)({
14
+ const client = (0, _redis.createClient)({
14
15
  url: redisURL,
15
16
  ...redisOptions
16
17
  });
18
+ client.on('error', err => {
19
+ _logger.logger.error('RedisPubSub Publisher client error', {
20
+ error: err
21
+ });
22
+ });
23
+ client.on('connect', () => {});
24
+ client.on('reconnecting', () => {});
25
+ client.on('ready', () => {});
26
+ return client;
17
27
  }
18
28
  function createSubscriber({
19
29
  redisURL,
20
30
  redisOptions = {}
21
31
  }) {
22
32
  redisOptions.no_ready_check = true;
23
- return (0, _redis.createClient)({
33
+ const client = (0, _redis.createClient)({
24
34
  url: redisURL,
25
35
  ...redisOptions
26
36
  });
37
+ client.on('error', err => {
38
+ _logger.logger.error('RedisPubSub Subscriber client error', {
39
+ error: err
40
+ });
41
+ });
42
+ client.on('connect', () => {});
43
+ client.on('reconnecting', () => {});
44
+ client.on('ready', () => {});
45
+ return client;
27
46
  }
28
47
  const RedisPubSub = exports.RedisPubSub = {
29
48
  createPublisher,
30
49
  createSubscriber
31
50
  };
32
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJfcmVkaXMiLCJyZXF1aXJlIiwiY3JlYXRlUHVibGlzaGVyIiwicmVkaXNVUkwiLCJyZWRpc09wdGlvbnMiLCJub19yZWFkeV9jaGVjayIsImNyZWF0ZUNsaWVudCIsInVybCIsImNyZWF0ZVN1YnNjcmliZXIiLCJSZWRpc1B1YlN1YiIsImV4cG9ydHMiXSwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvQWRhcHRlcnMvUHViU3ViL1JlZGlzUHViU3ViLmpzIl0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IGNyZWF0ZUNsaWVudCB9IGZyb20gJ3JlZGlzJztcblxuZnVuY3Rpb24gY3JlYXRlUHVibGlzaGVyKHsgcmVkaXNVUkwsIHJlZGlzT3B0aW9ucyA9IHt9IH0pOiBhbnkge1xuICByZWRpc09wdGlvbnMubm9fcmVhZHlfY2hlY2sgPSB0cnVlO1xuICByZXR1cm4gY3JlYXRlQ2xpZW50KHsgdXJsOiByZWRpc1VSTCwgLi4ucmVkaXNPcHRpb25zIH0pO1xufVxuXG5mdW5jdGlvbiBjcmVhdGVTdWJzY3JpYmVyKHsgcmVkaXNVUkwsIHJlZGlzT3B0aW9ucyA9IHt9IH0pOiBhbnkge1xuICByZWRpc09wdGlvbnMubm9fcmVhZHlfY2hlY2sgPSB0cnVlO1xuICByZXR1cm4gY3JlYXRlQ2xpZW50KHsgdXJsOiByZWRpc1VSTCwgLi4ucmVkaXNPcHRpb25zIH0pO1xufVxuXG5jb25zdCBSZWRpc1B1YlN1YiA9IHtcbiAgY3JlYXRlUHVibGlzaGVyLFxuICBjcmVhdGVTdWJzY3JpYmVyLFxufTtcblxuZXhwb3J0IHsgUmVkaXNQdWJTdWIgfTtcbiJdLCJtYXBwaW5ncyI6Ijs7Ozs7O0FBQUEsSUFBQUEsTUFBQSxHQUFBQyxPQUFBO0FBRUEsU0FBU0MsZUFBZUEsQ0FBQztFQUFFQyxRQUFRO0VBQUVDLFlBQVksR0FBRyxDQUFDO0FBQUUsQ0FBQyxFQUFPO0VBQzdEQSxZQUFZLENBQUNDLGNBQWMsR0FBRyxJQUFJO0VBQ2xDLE9BQU8sSUFBQUMsbUJBQVksRUFBQztJQUFFQyxHQUFHLEVBQUVKLFFBQVE7SUFBRSxHQUFHQztFQUFhLENBQUMsQ0FBQztBQUN6RDtBQUVBLFNBQVNJLGdCQUFnQkEsQ0FBQztFQUFFTCxRQUFRO0VBQUVDLFlBQVksR0FBRyxDQUFDO0FBQUUsQ0FBQyxFQUFPO0VBQzlEQSxZQUFZLENBQUNDLGNBQWMsR0FBRyxJQUFJO0VBQ2xDLE9BQU8sSUFBQUMsbUJBQVksRUFBQztJQUFFQyxHQUFHLEVBQUVKLFFBQVE7SUFBRSxHQUFHQztFQUFhLENBQUMsQ0FBQztBQUN6RDtBQUVBLE1BQU1LLFdBQVcsR0FBQUMsT0FBQSxDQUFBRCxXQUFBLEdBQUc7RUFDbEJQLGVBQWU7RUFDZk07QUFDRixDQUFDIiwiaWdub3JlTGlzdCI6W119
51
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJfcmVkaXMiLCJyZXF1aXJlIiwiX2xvZ2dlciIsImNyZWF0ZVB1Ymxpc2hlciIsInJlZGlzVVJMIiwicmVkaXNPcHRpb25zIiwibm9fcmVhZHlfY2hlY2siLCJjbGllbnQiLCJjcmVhdGVDbGllbnQiLCJ1cmwiLCJvbiIsImVyciIsImxvZ2dlciIsImVycm9yIiwiY3JlYXRlU3Vic2NyaWJlciIsIlJlZGlzUHViU3ViIiwiZXhwb3J0cyJdLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9BZGFwdGVycy9QdWJTdWIvUmVkaXNQdWJTdWIuanMiXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgY3JlYXRlQ2xpZW50IH0gZnJvbSAncmVkaXMnO1xuaW1wb3J0IHsgbG9nZ2VyIH0gZnJvbSAnLi4vLi4vbG9nZ2VyJztcblxuZnVuY3Rpb24gY3JlYXRlUHVibGlzaGVyKHsgcmVkaXNVUkwsIHJlZGlzT3B0aW9ucyA9IHt9IH0pOiBhbnkge1xuICByZWRpc09wdGlvbnMubm9fcmVhZHlfY2hlY2sgPSB0cnVlO1xuICBjb25zdCBjbGllbnQgPSBjcmVhdGVDbGllbnQoeyB1cmw6IHJlZGlzVVJMLCAuLi5yZWRpc09wdGlvbnMgfSk7XG4gIGNsaWVudC5vbignZXJyb3InLCBlcnIgPT4geyBsb2dnZXIuZXJyb3IoJ1JlZGlzUHViU3ViIFB1Ymxpc2hlciBjbGllbnQgZXJyb3InLCB7IGVycm9yOiBlcnIgfSkgfSk7XG4gIGNsaWVudC5vbignY29ubmVjdCcsICgpID0+IHt9KTtcbiAgY2xpZW50Lm9uKCdyZWNvbm5lY3RpbmcnLCAoKSA9PiB7fSk7XG4gIGNsaWVudC5vbigncmVhZHknLCAoKSA9PiB7fSk7XG4gIHJldHVybiBjbGllbnQ7XG59XG5cbmZ1bmN0aW9uIGNyZWF0ZVN1YnNjcmliZXIoeyByZWRpc1VSTCwgcmVkaXNPcHRpb25zID0ge30gfSk6IGFueSB7XG4gIHJlZGlzT3B0aW9ucy5ub19yZWFkeV9jaGVjayA9IHRydWU7XG4gIGNvbnN0IGNsaWVudCA9IGNyZWF0ZUNsaWVudCh7IHVybDogcmVkaXNVUkwsIC4uLnJlZGlzT3B0aW9ucyB9KTtcbiAgY2xpZW50Lm9uKCdlcnJvcicsIGVyciA9PiB7IGxvZ2dlci5lcnJvcignUmVkaXNQdWJTdWIgU3Vic2NyaWJlciBjbGllbnQgZXJyb3InLCB7IGVycm9yOiBlcnIgfSkgfSk7XG4gIGNsaWVudC5vbignY29ubmVjdCcsICgpID0+IHt9KTtcbiAgY2xpZW50Lm9uKCdyZWNvbm5lY3RpbmcnLCAoKSA9PiB7fSk7XG4gIGNsaWVudC5vbigncmVhZHknLCAoKSA9PiB7fSk7XG4gIHJldHVybiBjbGllbnQ7XG59XG5cbmNvbnN0IFJlZGlzUHViU3ViID0ge1xuICBjcmVhdGVQdWJsaXNoZXIsXG4gIGNyZWF0ZVN1YnNjcmliZXIsXG59O1xuXG5leHBvcnQgeyBSZWRpc1B1YlN1YiB9O1xuIl0sIm1hcHBpbmdzIjoiOzs7Ozs7QUFBQSxJQUFBQSxNQUFBLEdBQUFDLE9BQUE7QUFDQSxJQUFBQyxPQUFBLEdBQUFELE9BQUE7QUFFQSxTQUFTRSxlQUFlQSxDQUFDO0VBQUVDLFFBQVE7RUFBRUMsWUFBWSxHQUFHLENBQUM7QUFBRSxDQUFDLEVBQU87RUFDN0RBLFlBQVksQ0FBQ0MsY0FBYyxHQUFHLElBQUk7RUFDbEMsTUFBTUMsTUFBTSxHQUFHLElBQUFDLG1CQUFZLEVBQUM7SUFBRUMsR0FBRyxFQUFFTCxRQUFRO0lBQUUsR0FBR0M7RUFBYSxDQUFDLENBQUM7RUFDL0RFLE1BQU0sQ0FBQ0csRUFBRSxDQUFDLE9BQU8sRUFBRUMsR0FBRyxJQUFJO0lBQUVDLGNBQU0sQ0FBQ0MsS0FBSyxDQUFDLG9DQUFvQyxFQUFFO01BQUVBLEtBQUssRUFBRUY7SUFBSSxDQUFDLENBQUM7RUFBQyxDQUFDLENBQUM7RUFDakdKLE1BQU0sQ0FBQ0csRUFBRSxDQUFDLFNBQVMsRUFBRSxNQUFNLENBQUMsQ0FBQyxDQUFDO0VBQzlCSCxNQUFNLENBQUNHLEVBQUUsQ0FBQyxjQUFjLEVBQUUsTUFBTSxDQUFDLENBQUMsQ0FBQztFQUNuQ0gsTUFBTSxDQUFDRyxFQUFFLENBQUMsT0FBTyxFQUFFLE1BQU0sQ0FBQyxDQUFDLENBQUM7RUFDNUIsT0FBT0gsTUFBTTtBQUNmO0FBRUEsU0FBU08sZ0JBQWdCQSxDQUFDO0VBQUVWLFFBQVE7RUFBRUMsWUFBWSxHQUFHLENBQUM7QUFBRSxDQUFDLEVBQU87RUFDOURBLFlBQVksQ0FBQ0MsY0FBYyxHQUFHLElBQUk7RUFDbEMsTUFBTUMsTUFBTSxHQUFHLElBQUFDLG1CQUFZLEVBQUM7SUFBRUMsR0FBRyxFQUFFTCxRQUFRO0lBQUUsR0FBR0M7RUFBYSxDQUFDLENBQUM7RUFDL0RFLE1BQU0sQ0FBQ0csRUFBRSxDQUFDLE9BQU8sRUFBRUMsR0FBRyxJQUFJO0lBQUVDLGNBQU0sQ0FBQ0MsS0FBSyxDQUFDLHFDQUFxQyxFQUFFO01BQUVBLEtBQUssRUFBRUY7SUFBSSxDQUFDLENBQUM7RUFBQyxDQUFDLENBQUM7RUFDbEdKLE1BQU0sQ0FBQ0csRUFBRSxDQUFDLFNBQVMsRUFBRSxNQUFNLENBQUMsQ0FBQyxDQUFDO0VBQzlCSCxNQUFNLENBQUNHLEVBQUUsQ0FBQyxjQUFjLEVBQUUsTUFBTSxDQUFDLENBQUMsQ0FBQztFQUNuQ0gsTUFBTSxDQUFDRyxFQUFFLENBQUMsT0FBTyxFQUFFLE1BQU0sQ0FBQyxDQUFDLENBQUM7RUFDNUIsT0FBT0gsTUFBTTtBQUNmO0FBRUEsTUFBTVEsV0FBVyxHQUFBQyxPQUFBLENBQUFELFdBQUEsR0FBRztFQUNsQlosZUFBZTtFQUNmVztBQUNGLENBQUMiLCJpZ25vcmVMaXN0IjpbXX0=
@@ -50,14 +50,13 @@ class UserController extends _AdaptableController.default {
50
50
  }
51
51
  return true;
52
52
  }
53
- async verifyEmail(username, token) {
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
- var findUserForEmailVerification = await RestQuery({
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(username, token) {
101
- return this.config.database.find('_User', {
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)).then(results => {
107
- if (results.length != 1) {
108
- throw 'Failed to reset password: username / email / token is invalid';
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 (this.config.passwordPolicy && this.config.passwordPolicy.resetTokenValidityDuration) {
111
- let expiresDate = results[0]._perishable_token_expires_at;
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
- return results[0];
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 username = encodeURIComponent(fetchedUser.username);
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: 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 username = encodeURIComponent(user.username);
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(username, token, password) {
299
- return this.checkResetTokenValidity(username, token).then(user => updateUserPassword(user, password, this.config)).then(user => {
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
- }).catch(error => {
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, username, token, config) {
351
- const usernameAndToken = `token=${token}&username=${username}`;
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)}&${usernameAndToken}`;
349
+ return `${config.parseFrameURL}?link=${encodeURIComponent(destinationWithoutHost)}&${token}`;
355
350
  } else {
356
- return `${destination}?${usernameAndToken}`;
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":[]}