parse-server 6.0.0-alpha.9 → 6.0.0-beta.1

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.
Files changed (192) hide show
  1. package/LICENSE +167 -25
  2. package/NOTICE +10 -0
  3. package/README.md +57 -33
  4. package/lib/AccountLockout.js +11 -26
  5. package/lib/Adapters/AdapterLoader.js +8 -14
  6. package/lib/Adapters/Analytics/AnalyticsAdapter.js +2 -8
  7. package/lib/Adapters/Auth/AuthAdapter.js +7 -16
  8. package/lib/Adapters/Auth/OAuth1Client.js +32 -57
  9. package/lib/Adapters/Auth/apple.js +6 -22
  10. package/lib/Adapters/Auth/facebook.js +7 -37
  11. package/lib/Adapters/Auth/gcenter.js +8 -37
  12. package/lib/Adapters/Auth/github.js +7 -10
  13. package/lib/Adapters/Auth/google.js +11 -34
  14. package/lib/Adapters/Auth/gpgames.js +5 -8
  15. package/lib/Adapters/Auth/httpsRequest.js +1 -7
  16. package/lib/Adapters/Auth/index.js +20 -65
  17. package/lib/Adapters/Auth/instagram.js +5 -9
  18. package/lib/Adapters/Auth/janraincapture.js +8 -12
  19. package/lib/Adapters/Auth/janrainengage.js +7 -11
  20. package/lib/Adapters/Auth/keycloak.js +5 -19
  21. package/lib/Adapters/Auth/ldap.js +1 -15
  22. package/lib/Adapters/Auth/line.js +7 -10
  23. package/lib/Adapters/Auth/linkedin.js +7 -12
  24. package/lib/Adapters/Auth/meetup.js +7 -10
  25. package/lib/Adapters/Auth/microsoft.js +7 -10
  26. package/lib/Adapters/Auth/oauth2.js +6 -18
  27. package/lib/Adapters/Auth/phantauth.js +8 -10
  28. package/lib/Adapters/Auth/qq.js +7 -13
  29. package/lib/Adapters/Auth/spotify.js +7 -14
  30. package/lib/Adapters/Auth/twitter.js +5 -15
  31. package/lib/Adapters/Auth/vkontakte.js +9 -15
  32. package/lib/Adapters/Auth/wechat.js +7 -10
  33. package/lib/Adapters/Auth/weibo.js +7 -11
  34. package/lib/Adapters/Cache/CacheAdapter.js +4 -12
  35. package/lib/Adapters/Cache/InMemoryCache.js +5 -19
  36. package/lib/Adapters/Cache/InMemoryCacheAdapter.js +1 -11
  37. package/lib/Adapters/Cache/LRUCache.js +1 -11
  38. package/lib/Adapters/Cache/NullCacheAdapter.js +1 -8
  39. package/lib/Adapters/Cache/RedisCacheAdapter.js +3 -30
  40. package/lib/Adapters/Cache/SchemaCache.js +1 -6
  41. package/lib/Adapters/Email/MailAdapter.js +2 -7
  42. package/lib/Adapters/Files/FilesAdapter.js +7 -21
  43. package/lib/Adapters/Files/GridFSBucketAdapter.js +6 -44
  44. package/lib/Adapters/Files/GridStoreAdapter.js +1 -1
  45. package/lib/Adapters/Logger/LoggerAdapter.js +2 -11
  46. package/lib/Adapters/Logger/WinstonLogger.js +3 -30
  47. package/lib/Adapters/Logger/WinstonLoggerAdapter.js +5 -16
  48. package/lib/Adapters/MessageQueue/EventEmitterMQ.js +3 -20
  49. package/lib/Adapters/PubSub/EventEmitterPubSub.js +1 -16
  50. package/lib/Adapters/PubSub/PubSubAdapter.js +2 -9
  51. package/lib/Adapters/PubSub/RedisPubSub.js +12 -7
  52. package/lib/Adapters/Push/PushAdapter.js +2 -8
  53. package/lib/Adapters/Storage/Mongo/MongoCollection.js +12 -37
  54. package/lib/Adapters/Storage/Mongo/MongoSchemaCollection.js +26 -79
  55. package/lib/Adapters/Storage/Mongo/MongoStorageAdapter.js +78 -209
  56. package/lib/Adapters/Storage/Mongo/MongoTransform.js +82 -371
  57. package/lib/Adapters/Storage/Postgres/PostgresClient.js +1 -13
  58. package/lib/Adapters/Storage/Postgres/PostgresConfigParser.js +1 -20
  59. package/lib/Adapters/Storage/Postgres/PostgresStorageAdapter.js +119 -446
  60. package/lib/Adapters/Storage/Postgres/sql/index.js +4 -7
  61. package/lib/Adapters/Storage/StorageAdapter.js +1 -1
  62. package/lib/Adapters/WebSocketServer/WSAdapter.js +3 -12
  63. package/lib/Adapters/WebSocketServer/WSSAdapter.js +7 -12
  64. package/lib/Auth.js +68 -121
  65. package/lib/ClientSDK.js +3 -11
  66. package/lib/Config.js +73 -115
  67. package/lib/Controllers/AdaptableController.js +6 -18
  68. package/lib/Controllers/AnalyticsController.js +1 -9
  69. package/lib/Controllers/CacheController.js +3 -23
  70. package/lib/Controllers/DatabaseController.js +171 -364
  71. package/lib/Controllers/FilesController.js +5 -34
  72. package/lib/Controllers/HooksController.js +1 -51
  73. package/lib/Controllers/LiveQueryController.js +4 -23
  74. package/lib/Controllers/LoggerController.js +15 -54
  75. package/lib/Controllers/ParseGraphQLController.js +49 -104
  76. package/lib/Controllers/PushController.js +20 -59
  77. package/lib/Controllers/SchemaController.js +162 -348
  78. package/lib/Controllers/UserController.js +17 -78
  79. package/lib/Controllers/index.js +19 -68
  80. package/lib/Controllers/types.js +1 -1
  81. package/lib/Deprecator/Deprecations.js +1 -1
  82. package/lib/Deprecator/Deprecator.js +9 -18
  83. package/lib/GraphQL/ParseGraphQLSchema.js +16 -100
  84. package/lib/GraphQL/ParseGraphQLServer.js +2 -29
  85. package/lib/GraphQL/helpers/objectsMutations.js +2 -12
  86. package/lib/GraphQL/helpers/objectsQueries.js +18 -76
  87. package/lib/GraphQL/loaders/defaultGraphQLMutations.js +1 -9
  88. package/lib/GraphQL/loaders/defaultGraphQLQueries.js +1 -8
  89. package/lib/GraphQL/loaders/defaultGraphQLTypes.js +9 -115
  90. package/lib/GraphQL/loaders/defaultRelaySchema.js +6 -18
  91. package/lib/GraphQL/loaders/filesMutations.js +2 -19
  92. package/lib/GraphQL/loaders/functionsMutations.js +6 -17
  93. package/lib/GraphQL/loaders/parseClassMutations.js +6 -44
  94. package/lib/GraphQL/loaders/parseClassQueries.js +1 -26
  95. package/lib/GraphQL/loaders/parseClassTypes.js +10 -64
  96. package/lib/GraphQL/loaders/schemaDirectives.js +1 -17
  97. package/lib/GraphQL/loaders/schemaMutations.js +1 -20
  98. package/lib/GraphQL/loaders/schemaQueries.js +1 -14
  99. package/lib/GraphQL/loaders/schemaTypes.js +2 -6
  100. package/lib/GraphQL/loaders/usersMutations.js +6 -28
  101. package/lib/GraphQL/loaders/usersQueries.js +4 -26
  102. package/lib/GraphQL/parseGraphQLUtils.js +6 -19
  103. package/lib/GraphQL/transformers/className.js +1 -4
  104. package/lib/GraphQL/transformers/constraintType.js +1 -20
  105. package/lib/GraphQL/transformers/inputType.js +1 -20
  106. package/lib/GraphQL/transformers/mutation.js +6 -51
  107. package/lib/GraphQL/transformers/outputType.js +1 -20
  108. package/lib/GraphQL/transformers/query.js +6 -42
  109. package/lib/GraphQL/transformers/schemaFields.js +7 -34
  110. package/lib/KeyPromiseQueue.js +1 -12
  111. package/lib/LiveQuery/Client.js +1 -25
  112. package/lib/LiveQuery/Id.js +1 -7
  113. package/lib/LiveQuery/ParseCloudCodePublisher.js +13 -19
  114. package/lib/LiveQuery/ParseLiveQueryServer.js +111 -307
  115. package/lib/LiveQuery/ParsePubSub.js +1 -12
  116. package/lib/LiveQuery/ParseWebSocketServer.js +4 -26
  117. package/lib/LiveQuery/QueryTools.js +14 -116
  118. package/lib/LiveQuery/RequestSchema.js +1 -1
  119. package/lib/LiveQuery/SessionTokenCache.js +1 -17
  120. package/lib/LiveQuery/Subscription.js +4 -18
  121. package/lib/LiveQuery/equalObjects.js +2 -14
  122. package/lib/Options/Definitions.js +88 -8
  123. package/lib/Options/docs.js +25 -3
  124. package/lib/Options/index.js +4 -12
  125. package/lib/Options/parsers.js +1 -18
  126. package/lib/Page.js +1 -9
  127. package/lib/ParseMessageQueue.js +1 -10
  128. package/lib/ParseServer.js +175 -207
  129. package/lib/ParseServerRESTController.js +6 -33
  130. package/lib/PromiseRouter.js +16 -50
  131. package/lib/Push/PushQueue.js +3 -15
  132. package/lib/Push/PushWorker.js +7 -32
  133. package/lib/Push/utils.js +9 -38
  134. package/lib/RestQuery.js +105 -242
  135. package/lib/RestWrite.js +224 -389
  136. package/lib/Routers/AggregateRouter.js +14 -51
  137. package/lib/Routers/AnalyticsRouter.js +2 -8
  138. package/lib/Routers/AudiencesRouter.js +1 -15
  139. package/lib/Routers/ClassesRouter.js +3 -53
  140. package/lib/Routers/CloudCodeRouter.js +1 -19
  141. package/lib/Routers/FeaturesRouter.js +1 -10
  142. package/lib/Routers/FilesRouter.js +29 -76
  143. package/lib/Routers/FunctionsRouter.js +5 -28
  144. package/lib/Routers/GlobalConfigRouter.js +4 -18
  145. package/lib/Routers/GraphQLRouter.js +1 -14
  146. package/lib/Routers/HooksRouter.js +1 -29
  147. package/lib/Routers/IAPValidationRouter.js +6 -29
  148. package/lib/Routers/InstallationsRouter.js +2 -12
  149. package/lib/Routers/LogsRouter.js +4 -16
  150. package/lib/Routers/PagesRouter.js +69 -129
  151. package/lib/Routers/PublicAPIRouter.js +3 -62
  152. package/lib/Routers/PurgeRouter.js +1 -15
  153. package/lib/Routers/PushRouter.js +2 -18
  154. package/lib/Routers/RolesRouter.js +1 -7
  155. package/lib/Routers/SchemasRouter.js +4 -34
  156. package/lib/Routers/SecurityRouter.js +1 -12
  157. package/lib/Routers/SessionsRouter.js +3 -19
  158. package/lib/Routers/UsersRouter.js +48 -135
  159. package/lib/SchemaMigrations/DefinedSchemas.js +56 -115
  160. package/lib/SchemaMigrations/Migrations.js +2 -8
  161. package/lib/Security/Check.js +8 -16
  162. package/lib/Security/CheckGroup.js +4 -11
  163. package/lib/Security/CheckGroups/CheckGroupDatabase.js +8 -18
  164. package/lib/Security/CheckGroups/CheckGroupServerConfig.js +5 -15
  165. package/lib/Security/CheckGroups/CheckGroups.js +1 -4
  166. package/lib/Security/CheckRunner.js +22 -41
  167. package/lib/StatusHandler.js +12 -69
  168. package/lib/TestUtils.js +1 -6
  169. package/lib/Utils.js +27 -66
  170. package/lib/batch.js +17 -28
  171. package/lib/cache.js +1 -3
  172. package/lib/cli/definitions/parse-live-query-server.js +1 -3
  173. package/lib/cli/definitions/parse-server.js +1 -3
  174. package/lib/cli/parse-live-query-server.js +1 -6
  175. package/lib/cli/parse-server.js +11 -21
  176. package/lib/cli/utils/commander.js +13 -51
  177. package/lib/cli/utils/runner.js +1 -14
  178. package/lib/cloud-code/Parse.Cloud.js +71 -81
  179. package/lib/cryptoUtils.js +11 -19
  180. package/lib/defaults.js +2 -14
  181. package/lib/deprecated.js +1 -2
  182. package/lib/index.js +16 -34
  183. package/lib/logger.js +6 -13
  184. package/lib/middlewares.js +166 -148
  185. package/lib/password.js +6 -10
  186. package/lib/request.js +8 -42
  187. package/lib/requiredParameter.js +1 -3
  188. package/lib/rest.js +25 -47
  189. package/lib/triggers.js +54 -252
  190. package/lib/vendor/mongodbUrl.js +129 -310
  191. package/package.json +13 -10
  192. package/PATENTS +0 -37
@@ -4,73 +4,52 @@ Object.defineProperty(exports, "__esModule", {
4
4
  value: true
5
5
  });
6
6
  exports.default = exports.UserController = void 0;
7
-
8
7
  var _cryptoUtils = require("../cryptoUtils");
9
-
10
8
  var _triggers = require("../triggers");
11
-
12
9
  var _AdaptableController = _interopRequireDefault(require("./AdaptableController"));
13
-
14
10
  var _MailAdapter = _interopRequireDefault(require("../Adapters/Email/MailAdapter"));
15
-
16
11
  var _rest = _interopRequireDefault(require("../rest"));
17
-
18
12
  var _node = _interopRequireDefault(require("parse/node"));
19
-
20
13
  var _AccountLockout = _interopRequireDefault(require("../AccountLockout"));
21
-
22
14
  var _Config = _interopRequireDefault(require("../Config"));
23
-
24
15
  function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
25
-
26
16
  var RestQuery = require('../RestQuery');
27
-
28
17
  var Auth = require('../Auth');
29
-
30
18
  class UserController extends _AdaptableController.default {
31
19
  constructor(adapter, appId, options = {}) {
32
20
  super(adapter, appId, options);
33
21
  }
34
-
35
22
  get config() {
36
23
  return _Config.default.get(this.appId);
37
24
  }
38
-
39
25
  validateAdapter(adapter) {
40
26
  // Allow no adapter
41
27
  if (!adapter && !this.shouldVerifyEmails) {
42
28
  return;
43
29
  }
44
-
45
30
  super.validateAdapter(adapter);
46
31
  }
47
-
48
32
  expectedAdapterType() {
49
33
  return _MailAdapter.default;
50
34
  }
51
-
52
35
  get shouldVerifyEmails() {
53
36
  return this.options.verifyUserEmails;
54
37
  }
55
-
56
38
  setEmailVerifyToken(user) {
57
39
  if (this.shouldVerifyEmails) {
58
40
  user._email_verify_token = (0, _cryptoUtils.randomString)(25);
59
41
  user.emailVerified = false;
60
-
61
42
  if (this.config.emailVerifyTokenValidityDuration) {
62
43
  user._email_verify_token_expires_at = _node.default._encode(this.config.generateEmailVerifyTokenExpiresAt());
63
44
  }
64
45
  }
65
46
  }
66
-
67
47
  verifyEmail(username, token) {
68
48
  if (!this.shouldVerifyEmails) {
69
49
  // Trying to verify email when not enabled
70
50
  // TODO: Better error here.
71
51
  throw undefined;
72
52
  }
73
-
74
53
  const query = {
75
54
  username: username,
76
55
  _email_verify_token: token
@@ -80,9 +59,10 @@ class UserController extends _AdaptableController.default {
80
59
  _email_verify_token: {
81
60
  __op: 'Delete'
82
61
  }
83
- }; // if the email verify token needs to be validated then
84
- // add additional query params and additional fields that need to be updated
62
+ };
85
63
 
64
+ // if the email verify token needs to be validated then
65
+ // add additional query params and additional fields that need to be updated
86
66
  if (this.config.emailVerifyTokenValidityDuration) {
87
67
  query.emailVerified = false;
88
68
  query._email_verify_token_expires_at = {
@@ -92,10 +72,9 @@ class UserController extends _AdaptableController.default {
92
72
  __op: 'Delete'
93
73
  };
94
74
  }
95
-
96
- const masterAuth = Auth.master(this.config);
97
- var findUserForEmailVerification = new RestQuery(this.config, Auth.master(this.config), '_User', {
98
- username: username
75
+ const maintenanceAuth = Auth.maintenance(this.config);
76
+ var findUserForEmailVerification = new RestQuery(this.config, maintenanceAuth, '_User', {
77
+ username
99
78
  });
100
79
  return findUserForEmailVerification.execute().then(result => {
101
80
  if (result.results.length && result.results[0].emailVerified) {
@@ -103,68 +82,54 @@ class UserController extends _AdaptableController.default {
103
82
  } else if (result.results.length) {
104
83
  query.objectId = result.results[0].objectId;
105
84
  }
106
-
107
- return _rest.default.update(this.config, masterAuth, '_User', query, updateFields);
85
+ return _rest.default.update(this.config, maintenanceAuth, '_User', query, updateFields);
108
86
  });
109
87
  }
110
-
111
88
  checkResetTokenValidity(username, token) {
112
89
  return this.config.database.find('_User', {
113
90
  username: username,
114
91
  _perishable_token: token
115
92
  }, {
116
93
  limit: 1
117
- }).then(results => {
94
+ }, Auth.maintenance(this.config)).then(results => {
118
95
  if (results.length != 1) {
119
96
  throw 'Failed to reset password: username / email / token is invalid';
120
97
  }
121
-
122
98
  if (this.config.passwordPolicy && this.config.passwordPolicy.resetTokenValidityDuration) {
123
99
  let expiresDate = results[0]._perishable_token_expires_at;
124
-
125
100
  if (expiresDate && expiresDate.__type == 'Date') {
126
101
  expiresDate = new Date(expiresDate.iso);
127
102
  }
128
-
129
103
  if (expiresDate < new Date()) throw 'The password reset link has expired';
130
104
  }
131
-
132
105
  return results[0];
133
106
  });
134
107
  }
135
-
136
108
  getUserIfNeeded(user) {
137
109
  if (user.username && user.email) {
138
110
  return Promise.resolve(user);
139
111
  }
140
-
141
112
  var where = {};
142
-
143
113
  if (user.username) {
144
114
  where.username = user.username;
145
115
  }
146
-
147
116
  if (user.email) {
148
117
  where.email = user.email;
149
118
  }
150
-
151
119
  var query = new RestQuery(this.config, Auth.master(this.config), '_User', where);
152
120
  return query.execute().then(function (result) {
153
121
  if (result.results.length != 1) {
154
122
  throw undefined;
155
123
  }
156
-
157
124
  return result.results[0];
158
125
  });
159
126
  }
160
-
161
127
  sendVerificationEmail(user) {
162
128
  if (!this.shouldVerifyEmails) {
163
129
  return;
164
130
  }
165
-
166
- const token = encodeURIComponent(user._email_verify_token); // We may need to fetch the user in case of update email
167
-
131
+ const token = encodeURIComponent(user._email_verify_token);
132
+ // We may need to fetch the user in case of update email
168
133
  this.getUserIfNeeded(user).then(user => {
169
134
  const username = encodeURIComponent(user.username);
170
135
  const link = buildEmailLink(this.config.verifyEmailURL, username, token, this.config);
@@ -173,7 +138,6 @@ class UserController extends _AdaptableController.default {
173
138
  link: link,
174
139
  user: (0, _triggers.inflate)('_User', user)
175
140
  };
176
-
177
141
  if (this.adapter.sendVerificationEmail) {
178
142
  this.adapter.sendVerificationEmail(options);
179
143
  } else {
@@ -181,14 +145,13 @@ class UserController extends _AdaptableController.default {
181
145
  }
182
146
  });
183
147
  }
148
+
184
149
  /**
185
150
  * Regenerates the given user's email verification token
186
151
  *
187
152
  * @param user
188
153
  * @returns {*}
189
154
  */
190
-
191
-
192
155
  regenerateEmailVerifyToken(user) {
193
156
  const {
194
157
  _email_verify_token
@@ -196,21 +159,17 @@ class UserController extends _AdaptableController.default {
196
159
  let {
197
160
  _email_verify_token_expires_at
198
161
  } = user;
199
-
200
162
  if (_email_verify_token_expires_at && _email_verify_token_expires_at.__type === 'Date') {
201
163
  _email_verify_token_expires_at = _email_verify_token_expires_at.iso;
202
164
  }
203
-
204
165
  if (this.config.emailVerifyTokenReuseIfValid && this.config.emailVerifyTokenValidityDuration && _email_verify_token && new Date() < new Date(_email_verify_token_expires_at)) {
205
166
  return Promise.resolve();
206
167
  }
207
-
208
168
  this.setEmailVerifyToken(user);
209
169
  return this.config.database.update('_User', {
210
170
  username: user.username
211
171
  }, user);
212
172
  }
213
-
214
173
  resendVerificationEmail(username) {
215
174
  return this.getUserIfNeeded({
216
175
  username: username
@@ -218,22 +177,18 @@ class UserController extends _AdaptableController.default {
218
177
  if (!aUser || aUser.emailVerified) {
219
178
  throw undefined;
220
179
  }
221
-
222
180
  return this.regenerateEmailVerifyToken(aUser).then(() => {
223
181
  this.sendVerificationEmail(aUser);
224
182
  });
225
183
  });
226
184
  }
227
-
228
185
  setPasswordResetToken(email) {
229
186
  const token = {
230
187
  _perishable_token: (0, _cryptoUtils.randomString)(25)
231
188
  };
232
-
233
189
  if (this.config.passwordPolicy && this.config.passwordPolicy.resetTokenValidityDuration) {
234
190
  token._perishable_token_expires_at = _node.default._encode(this.config.generatePasswordResetTokenExpiresAt());
235
191
  }
236
-
237
192
  return this.config.database.update('_User', {
238
193
  $or: [{
239
194
  email
@@ -245,14 +200,13 @@ class UserController extends _AdaptableController.default {
245
200
  }]
246
201
  }, token, {}, true);
247
202
  }
248
-
249
203
  async sendPasswordResetEmail(email) {
250
204
  if (!this.adapter) {
251
- throw 'Trying to send a reset password but no adapter is set'; // TODO: No adapter?
205
+ throw 'Trying to send a reset password but no adapter is set';
206
+ // TODO: No adapter?
252
207
  }
253
208
 
254
209
  let user;
255
-
256
210
  if (this.config.passwordPolicy && this.config.passwordPolicy.resetTokenReuseIfValid && this.config.passwordPolicy.resetTokenValidityDuration) {
257
211
  const results = await this.config.database.find('_User', {
258
212
  $or: [{
@@ -271,25 +225,20 @@ class UserController extends _AdaptableController.default {
271
225
  }]
272
226
  }, {
273
227
  limit: 1
274
- });
275
-
228
+ }, Auth.maintenance(this.config));
276
229
  if (results.length == 1) {
277
230
  let expiresDate = results[0]._perishable_token_expires_at;
278
-
279
231
  if (expiresDate && expiresDate.__type == 'Date') {
280
232
  expiresDate = new Date(expiresDate.iso);
281
233
  }
282
-
283
234
  if (expiresDate > new Date()) {
284
235
  user = results[0];
285
236
  }
286
237
  }
287
238
  }
288
-
289
239
  if (!user || !user._perishable_token) {
290
240
  user = await this.setPasswordResetToken(email);
291
241
  }
292
-
293
242
  const token = encodeURIComponent(user._perishable_token);
294
243
  const username = encodeURIComponent(user.username);
295
244
  const link = buildEmailLink(this.config.requestResetPasswordURL, username, token, this.config);
@@ -298,16 +247,13 @@ class UserController extends _AdaptableController.default {
298
247
  link: link,
299
248
  user: (0, _triggers.inflate)('_User', user)
300
249
  };
301
-
302
250
  if (this.adapter.sendPasswordResetEmail) {
303
251
  this.adapter.sendPasswordResetEmail(options);
304
252
  } else {
305
253
  this.adapter.sendMail(this.defaultResetPasswordEmail(options));
306
254
  }
307
-
308
255
  return Promise.resolve(user);
309
256
  }
310
-
311
257
  updatePassword(username, token, password) {
312
258
  return this.checkResetTokenValidity(username, token).then(user => updateUserPassword(user, password, this.config)).then(user => {
313
259
  const accountLockoutPolicy = new _AccountLockout.default(user, this.config);
@@ -321,7 +267,6 @@ class UserController extends _AdaptableController.default {
321
267
  }
322
268
  });
323
269
  }
324
-
325
270
  defaultVerificationEmail({
326
271
  link,
327
272
  user,
@@ -336,7 +281,6 @@ class UserController extends _AdaptableController.default {
336
281
  subject
337
282
  };
338
283
  }
339
-
340
284
  defaultResetPasswordEmail({
341
285
  link,
342
286
  user,
@@ -351,12 +295,10 @@ class UserController extends _AdaptableController.default {
351
295
  subject
352
296
  };
353
297
  }
298
+ }
354
299
 
355
- } // Mark this private
356
-
357
-
300
+ // Mark this private
358
301
  exports.UserController = UserController;
359
-
360
302
  function updateUserPassword(user, password, config) {
361
303
  return _rest.default.update(config, Auth.master(config), '_User', {
362
304
  objectId: user.objectId
@@ -364,10 +306,8 @@ function updateUserPassword(user, password, config) {
364
306
  password: password
365
307
  }).then(() => user);
366
308
  }
367
-
368
309
  function buildEmailLink(destination, username, token, config) {
369
310
  const usernameAndToken = `token=${token}&username=${username}`;
370
-
371
311
  if (config.parseFrameURL) {
372
312
  const destinationWithoutHost = destination.replace(config.publicServerURL, '');
373
313
  return `${config.parseFrameURL}?link=${encodeURIComponent(destinationWithoutHost)}&${usernameAndToken}`;
@@ -375,7 +315,6 @@ function buildEmailLink(destination, username, token, config) {
375
315
  return `${destination}?${usernameAndToken}`;
376
316
  }
377
317
  }
378
-
379
318
  var _default = UserController;
380
319
  exports.default = _default;
381
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/Controllers/UserController.js"],"names":["RestQuery","require","Auth","UserController","AdaptableController","constructor","adapter","appId","options","config","Config","get","validateAdapter","shouldVerifyEmails","expectedAdapterType","MailAdapter","verifyUserEmails","setEmailVerifyToken","user","_email_verify_token","emailVerified","emailVerifyTokenValidityDuration","_email_verify_token_expires_at","Parse","_encode","generateEmailVerifyTokenExpiresAt","verifyEmail","username","token","undefined","query","updateFields","__op","$gt","Date","masterAuth","master","findUserForEmailVerification","execute","then","result","results","length","Promise","resolve","objectId","rest","update","checkResetTokenValidity","database","find","_perishable_token","limit","passwordPolicy","resetTokenValidityDuration","expiresDate","_perishable_token_expires_at","__type","iso","getUserIfNeeded","email","where","sendVerificationEmail","encodeURIComponent","link","buildEmailLink","verifyEmailURL","appName","sendMail","defaultVerificationEmail","regenerateEmailVerifyToken","emailVerifyTokenReuseIfValid","resendVerificationEmail","aUser","setPasswordResetToken","generatePasswordResetTokenExpiresAt","$or","$exists","sendPasswordResetEmail","resetTokenReuseIfValid","requestResetPasswordURL","defaultResetPasswordEmail","updatePassword","password","updateUserPassword","accountLockoutPolicy","AccountLockout","unlockAccount","catch","error","message","reject","text","to","subject","destination","usernameAndToken","parseFrameURL","destinationWithoutHost","replace","publicServerURL"],"mappings":"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","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.options.verifyUserEmails;\n  }\n\n  setEmailVerifyToken(user) {\n    if (this.shouldVerifyEmails) {\n      user._email_verify_token = randomString(25);\n      user.emailVerified = false;\n\n      if (this.config.emailVerifyTokenValidityDuration) {\n        user._email_verify_token_expires_at = Parse._encode(\n          this.config.generateEmailVerifyTokenExpiresAt()\n        );\n      }\n    }\n  }\n\n  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 masterAuth = Auth.master(this.config);\n    var findUserForEmailVerification = new RestQuery(\n      this.config,\n      Auth.master(this.config),\n      '_User',\n      { username: username }\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, masterAuth, '_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      )\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  getUserIfNeeded(user) {\n    if (user.username && user.email) {\n      return Promise.resolve(user);\n    }\n    var where = {};\n    if (user.username) {\n      where.username = user.username;\n    }\n    if (user.email) {\n      where.email = user.email;\n    }\n\n    var query = new RestQuery(this.config, Auth.master(this.config), '_User', where);\n    return query.execute().then(function (result) {\n      if (result.results.length != 1) {\n        throw undefined;\n      }\n      return result.results[0];\n    });\n  }\n\n  sendVerificationEmail(user) {\n    if (!this.shouldVerifyEmails) {\n      return;\n    }\n    const token = encodeURIComponent(user._email_verify_token);\n    // We may need to fetch the user in case of update email\n    this.getUserIfNeeded(user).then(user => {\n      const username = encodeURIComponent(user.username);\n\n      const link = buildEmailLink(this.config.verifyEmailURL, username, token, this.config);\n      const options = {\n        appName: this.config.appName,\n        link: link,\n        user: inflate('_User', user),\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  /**\n   * Regenerates the given user's email verification token\n   *\n   * @param user\n   * @returns {*}\n   */\n  regenerateEmailVerifyToken(user) {\n    const { _email_verify_token } = user;\n    let { _email_verify_token_expires_at } = user;\n    if (_email_verify_token_expires_at && _email_verify_token_expires_at.__type === 'Date') {\n      _email_verify_token_expires_at = _email_verify_token_expires_at.iso;\n    }\n    if (\n      this.config.emailVerifyTokenReuseIfValid &&\n      this.config.emailVerifyTokenValidityDuration &&\n      _email_verify_token &&\n      new Date() < new Date(_email_verify_token_expires_at)\n    ) {\n      return Promise.resolve();\n    }\n    this.setEmailVerifyToken(user);\n    return this.config.database.update('_User', { username: user.username }, user);\n  }\n\n  resendVerificationEmail(username) {\n    return this.getUserIfNeeded({ username: username }).then(aUser => {\n      if (!aUser || aUser.emailVerified) {\n        throw undefined;\n      }\n      return this.regenerateEmailVerifyToken(aUser).then(() => {\n        this.sendVerificationEmail(aUser);\n      });\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      );\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"]}
320
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["RestQuery","require","Auth","UserController","AdaptableController","constructor","adapter","appId","options","config","Config","get","validateAdapter","shouldVerifyEmails","expectedAdapterType","MailAdapter","verifyUserEmails","setEmailVerifyToken","user","_email_verify_token","randomString","emailVerified","emailVerifyTokenValidityDuration","_email_verify_token_expires_at","Parse","_encode","generateEmailVerifyTokenExpiresAt","verifyEmail","username","token","undefined","query","updateFields","__op","$gt","Date","maintenanceAuth","maintenance","findUserForEmailVerification","execute","then","result","results","length","Promise","resolve","objectId","rest","update","checkResetTokenValidity","database","find","_perishable_token","limit","passwordPolicy","resetTokenValidityDuration","expiresDate","_perishable_token_expires_at","__type","iso","getUserIfNeeded","email","where","master","sendVerificationEmail","encodeURIComponent","link","buildEmailLink","verifyEmailURL","appName","inflate","sendMail","defaultVerificationEmail","regenerateEmailVerifyToken","emailVerifyTokenReuseIfValid","resendVerificationEmail","aUser","setPasswordResetToken","generatePasswordResetTokenExpiresAt","$or","$exists","sendPasswordResetEmail","resetTokenReuseIfValid","requestResetPasswordURL","defaultResetPasswordEmail","updatePassword","password","updateUserPassword","accountLockoutPolicy","AccountLockout","unlockAccount","catch","error","message","reject","text","to","subject","destination","usernameAndToken","parseFrameURL","destinationWithoutHost","replace","publicServerURL"],"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.options.verifyUserEmails;\n  }\n\n  setEmailVerifyToken(user) {\n    if (this.shouldVerifyEmails) {\n      user._email_verify_token = randomString(25);\n      user.emailVerified = false;\n\n      if (this.config.emailVerifyTokenValidityDuration) {\n        user._email_verify_token_expires_at = Parse._encode(\n          this.config.generateEmailVerifyTokenExpiresAt()\n        );\n      }\n    }\n  }\n\n  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 = new RestQuery(this.config, maintenanceAuth, '_User', {\n      username,\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  getUserIfNeeded(user) {\n    if (user.username && user.email) {\n      return Promise.resolve(user);\n    }\n    var where = {};\n    if (user.username) {\n      where.username = user.username;\n    }\n    if (user.email) {\n      where.email = user.email;\n    }\n\n    var query = new RestQuery(this.config, Auth.master(this.config), '_User', where);\n    return query.execute().then(function (result) {\n      if (result.results.length != 1) {\n        throw undefined;\n      }\n      return result.results[0];\n    });\n  }\n\n  sendVerificationEmail(user) {\n    if (!this.shouldVerifyEmails) {\n      return;\n    }\n    const token = encodeURIComponent(user._email_verify_token);\n    // We may need to fetch the user in case of update email\n    this.getUserIfNeeded(user).then(user => {\n      const username = encodeURIComponent(user.username);\n\n      const link = buildEmailLink(this.config.verifyEmailURL, username, token, this.config);\n      const options = {\n        appName: this.config.appName,\n        link: link,\n        user: inflate('_User', user),\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  /**\n   * Regenerates the given user's email verification token\n   *\n   * @param user\n   * @returns {*}\n   */\n  regenerateEmailVerifyToken(user) {\n    const { _email_verify_token } = user;\n    let { _email_verify_token_expires_at } = user;\n    if (_email_verify_token_expires_at && _email_verify_token_expires_at.__type === 'Date') {\n      _email_verify_token_expires_at = _email_verify_token_expires_at.iso;\n    }\n    if (\n      this.config.emailVerifyTokenReuseIfValid &&\n      this.config.emailVerifyTokenValidityDuration &&\n      _email_verify_token &&\n      new Date() < new Date(_email_verify_token_expires_at)\n    ) {\n      return Promise.resolve();\n    }\n    this.setEmailVerifyToken(user);\n    return this.config.database.update('_User', { username: user.username }, user);\n  }\n\n  resendVerificationEmail(username) {\n    return this.getUserIfNeeded({ username: username }).then(aUser => {\n      if (!aUser || aUser.emailVerified) {\n        throw undefined;\n      }\n      return this.regenerateEmailVerifyToken(aUser).then(() => {\n        this.sendVerificationEmail(aUser);\n      });\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":";;;;;;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAA+B;AAE/B,IAAIA,SAAS,GAAGC,OAAO,CAAC,cAAc,CAAC;AACvC,IAAIC,IAAI,GAAGD,OAAO,CAAC,SAAS,CAAC;AAEtB,MAAME,cAAc,SAASC,4BAAmB,CAAC;EACtDC,WAAW,CAACC,OAAO,EAAEC,KAAK,EAAEC,OAAO,GAAG,CAAC,CAAC,EAAE;IACxC,KAAK,CAACF,OAAO,EAAEC,KAAK,EAAEC,OAAO,CAAC;EAChC;EAEA,IAAIC,MAAM,GAAG;IACX,OAAOC,eAAM,CAACC,GAAG,CAAC,IAAI,CAACJ,KAAK,CAAC;EAC/B;EAEAK,eAAe,CAACN,OAAO,EAAE;IACvB;IACA,IAAI,CAACA,OAAO,IAAI,CAAC,IAAI,CAACO,kBAAkB,EAAE;MACxC;IACF;IACA,KAAK,CAACD,eAAe,CAACN,OAAO,CAAC;EAChC;EAEAQ,mBAAmB,GAAG;IACpB,OAAOC,oBAAW;EACpB;EAEA,IAAIF,kBAAkB,GAAG;IACvB,OAAO,IAAI,CAACL,OAAO,CAACQ,gBAAgB;EACtC;EAEAC,mBAAmB,CAACC,IAAI,EAAE;IACxB,IAAI,IAAI,CAACL,kBAAkB,EAAE;MAC3BK,IAAI,CAACC,mBAAmB,GAAG,IAAAC,yBAAY,EAAC,EAAE,CAAC;MAC3CF,IAAI,CAACG,aAAa,GAAG,KAAK;MAE1B,IAAI,IAAI,CAACZ,MAAM,CAACa,gCAAgC,EAAE;QAChDJ,IAAI,CAACK,8BAA8B,GAAGC,aAAK,CAACC,OAAO,CACjD,IAAI,CAAChB,MAAM,CAACiB,iCAAiC,EAAE,CAChD;MACH;IACF;EACF;EAEAC,WAAW,CAACC,QAAQ,EAAEC,KAAK,EAAE;IAC3B,IAAI,CAAC,IAAI,CAAChB,kBAAkB,EAAE;MAC5B;MACA;MACA,MAAMiB,SAAS;IACjB;IAEA,MAAMC,KAAK,GAAG;MAAEH,QAAQ,EAAEA,QAAQ;MAAET,mBAAmB,EAAEU;IAAM,CAAC;IAChE,MAAMG,YAAY,GAAG;MACnBX,aAAa,EAAE,IAAI;MACnBF,mBAAmB,EAAE;QAAEc,IAAI,EAAE;MAAS;IACxC,CAAC;;IAED;IACA;IACA,IAAI,IAAI,CAACxB,MAAM,CAACa,gCAAgC,EAAE;MAChDS,KAAK,CAACV,aAAa,GAAG,KAAK;MAC3BU,KAAK,CAACR,8BAA8B,GAAG;QAAEW,GAAG,EAAEV,aAAK,CAACC,OAAO,CAAC,IAAIU,IAAI,EAAE;MAAE,CAAC;MAEzEH,YAAY,CAACT,8BAA8B,GAAG;QAAEU,IAAI,EAAE;MAAS,CAAC;IAClE;IACA,MAAMG,eAAe,GAAGlC,IAAI,CAACmC,WAAW,CAAC,IAAI,CAAC5B,MAAM,CAAC;IACrD,IAAI6B,4BAA4B,GAAG,IAAItC,SAAS,CAAC,IAAI,CAACS,MAAM,EAAE2B,eAAe,EAAE,OAAO,EAAE;MACtFR;IACF,CAAC,CAAC;IACF,OAAOU,4BAA4B,CAACC,OAAO,EAAE,CAACC,IAAI,CAACC,MAAM,IAAI;MAC3D,IAAIA,MAAM,CAACC,OAAO,CAACC,MAAM,IAAIF,MAAM,CAACC,OAAO,CAAC,CAAC,CAAC,CAACrB,aAAa,EAAE;QAC5D,OAAOuB,OAAO,CAACC,OAAO,CAACJ,MAAM,CAACC,OAAO,CAACC,MAAM,CAAC,CAAC,CAAC,CAAC;MAClD,CAAC,MAAM,IAAIF,MAAM,CAACC,OAAO,CAACC,MAAM,EAAE;QAChCZ,KAAK,CAACe,QAAQ,GAAGL,MAAM,CAACC,OAAO,CAAC,CAAC,CAAC,CAACI,QAAQ;MAC7C;MACA,OAAOC,aAAI,CAACC,MAAM,CAAC,IAAI,CAACvC,MAAM,EAAE2B,eAAe,EAAE,OAAO,EAAEL,KAAK,EAAEC,YAAY,CAAC;IAChF,CAAC,CAAC;EACJ;EAEAiB,uBAAuB,CAACrB,QAAQ,EAAEC,KAAK,EAAE;IACvC,OAAO,IAAI,CAACpB,MAAM,CAACyC,QAAQ,CACxBC,IAAI,CACH,OAAO,EACP;MACEvB,QAAQ,EAAEA,QAAQ;MAClBwB,iBAAiB,EAAEvB;IACrB,CAAC,EACD;MAAEwB,KAAK,EAAE;IAAE,CAAC,EACZnD,IAAI,CAACmC,WAAW,CAAC,IAAI,CAAC5B,MAAM,CAAC,CAC9B,CACA+B,IAAI,CAACE,OAAO,IAAI;MACf,IAAIA,OAAO,CAACC,MAAM,IAAI,CAAC,EAAE;QACvB,MAAM,+DAA+D;MACvE;MAEA,IAAI,IAAI,CAAClC,MAAM,CAAC6C,cAAc,IAAI,IAAI,CAAC7C,MAAM,CAAC6C,cAAc,CAACC,0BAA0B,EAAE;QACvF,IAAIC,WAAW,GAAGd,OAAO,CAAC,CAAC,CAAC,CAACe,4BAA4B;QACzD,IAAID,WAAW,IAAIA,WAAW,CAACE,MAAM,IAAI,MAAM,EAAE;UAC/CF,WAAW,GAAG,IAAIrB,IAAI,CAACqB,WAAW,CAACG,GAAG,CAAC;QACzC;QACA,IAAIH,WAAW,GAAG,IAAIrB,IAAI,EAAE,EAAE,MAAM,qCAAqC;MAC3E;MACA,OAAOO,OAAO,CAAC,CAAC,CAAC;IACnB,CAAC,CAAC;EACN;EAEAkB,eAAe,CAAC1C,IAAI,EAAE;IACpB,IAAIA,IAAI,CAACU,QAAQ,IAAIV,IAAI,CAAC2C,KAAK,EAAE;MAC/B,OAAOjB,OAAO,CAACC,OAAO,CAAC3B,IAAI,CAAC;IAC9B;IACA,IAAI4C,KAAK,GAAG,CAAC,CAAC;IACd,IAAI5C,IAAI,CAACU,QAAQ,EAAE;MACjBkC,KAAK,CAAClC,QAAQ,GAAGV,IAAI,CAACU,QAAQ;IAChC;IACA,IAAIV,IAAI,CAAC2C,KAAK,EAAE;MACdC,KAAK,CAACD,KAAK,GAAG3C,IAAI,CAAC2C,KAAK;IAC1B;IAEA,IAAI9B,KAAK,GAAG,IAAI/B,SAAS,CAAC,IAAI,CAACS,MAAM,EAAEP,IAAI,CAAC6D,MAAM,CAAC,IAAI,CAACtD,MAAM,CAAC,EAAE,OAAO,EAAEqD,KAAK,CAAC;IAChF,OAAO/B,KAAK,CAACQ,OAAO,EAAE,CAACC,IAAI,CAAC,UAAUC,MAAM,EAAE;MAC5C,IAAIA,MAAM,CAACC,OAAO,CAACC,MAAM,IAAI,CAAC,EAAE;QAC9B,MAAMb,SAAS;MACjB;MACA,OAAOW,MAAM,CAACC,OAAO,CAAC,CAAC,CAAC;IAC1B,CAAC,CAAC;EACJ;EAEAsB,qBAAqB,CAAC9C,IAAI,EAAE;IAC1B,IAAI,CAAC,IAAI,CAACL,kBAAkB,EAAE;MAC5B;IACF;IACA,MAAMgB,KAAK,GAAGoC,kBAAkB,CAAC/C,IAAI,CAACC,mBAAmB,CAAC;IAC1D;IACA,IAAI,CAACyC,eAAe,CAAC1C,IAAI,CAAC,CAACsB,IAAI,CAACtB,IAAI,IAAI;MACtC,MAAMU,QAAQ,GAAGqC,kBAAkB,CAAC/C,IAAI,CAACU,QAAQ,CAAC;MAElD,MAAMsC,IAAI,GAAGC,cAAc,CAAC,IAAI,CAAC1D,MAAM,CAAC2D,cAAc,EAAExC,QAAQ,EAAEC,KAAK,EAAE,IAAI,CAACpB,MAAM,CAAC;MACrF,MAAMD,OAAO,GAAG;QACd6D,OAAO,EAAE,IAAI,CAAC5D,MAAM,CAAC4D,OAAO;QAC5BH,IAAI,EAAEA,IAAI;QACVhD,IAAI,EAAE,IAAAoD,iBAAO,EAAC,OAAO,EAAEpD,IAAI;MAC7B,CAAC;MACD,IAAI,IAAI,CAACZ,OAAO,CAAC0D,qBAAqB,EAAE;QACtC,IAAI,CAAC1D,OAAO,CAAC0D,qBAAqB,CAACxD,OAAO,CAAC;MAC7C,CAAC,MAAM;QACL,IAAI,CAACF,OAAO,CAACiE,QAAQ,CAAC,IAAI,CAACC,wBAAwB,CAAChE,OAAO,CAAC,CAAC;MAC/D;IACF,CAAC,CAAC;EACJ;;EAEA;AACF;AACA;AACA;AACA;AACA;EACEiE,0BAA0B,CAACvD,IAAI,EAAE;IAC/B,MAAM;MAAEC;IAAoB,CAAC,GAAGD,IAAI;IACpC,IAAI;MAAEK;IAA+B,CAAC,GAAGL,IAAI;IAC7C,IAAIK,8BAA8B,IAAIA,8BAA8B,CAACmC,MAAM,KAAK,MAAM,EAAE;MACtFnC,8BAA8B,GAAGA,8BAA8B,CAACoC,GAAG;IACrE;IACA,IACE,IAAI,CAAClD,MAAM,CAACiE,4BAA4B,IACxC,IAAI,CAACjE,MAAM,CAACa,gCAAgC,IAC5CH,mBAAmB,IACnB,IAAIgB,IAAI,EAAE,GAAG,IAAIA,IAAI,CAACZ,8BAA8B,CAAC,EACrD;MACA,OAAOqB,OAAO,CAACC,OAAO,EAAE;IAC1B;IACA,IAAI,CAAC5B,mBAAmB,CAACC,IAAI,CAAC;IAC9B,OAAO,IAAI,CAACT,MAAM,CAACyC,QAAQ,CAACF,MAAM,CAAC,OAAO,EAAE;MAAEpB,QAAQ,EAAEV,IAAI,CAACU;IAAS,CAAC,EAAEV,IAAI,CAAC;EAChF;EAEAyD,uBAAuB,CAAC/C,QAAQ,EAAE;IAChC,OAAO,IAAI,CAACgC,eAAe,CAAC;MAAEhC,QAAQ,EAAEA;IAAS,CAAC,CAAC,CAACY,IAAI,CAACoC,KAAK,IAAI;MAChE,IAAI,CAACA,KAAK,IAAIA,KAAK,CAACvD,aAAa,EAAE;QACjC,MAAMS,SAAS;MACjB;MACA,OAAO,IAAI,CAAC2C,0BAA0B,CAACG,KAAK,CAAC,CAACpC,IAAI,CAAC,MAAM;QACvD,IAAI,CAACwB,qBAAqB,CAACY,KAAK,CAAC;MACnC,CAAC,CAAC;IACJ,CAAC,CAAC;EACJ;EAEAC,qBAAqB,CAAChB,KAAK,EAAE;IAC3B,MAAMhC,KAAK,GAAG;MAAEuB,iBAAiB,EAAE,IAAAhC,yBAAY,EAAC,EAAE;IAAE,CAAC;IAErD,IAAI,IAAI,CAACX,MAAM,CAAC6C,cAAc,IAAI,IAAI,CAAC7C,MAAM,CAAC6C,cAAc,CAACC,0BAA0B,EAAE;MACvF1B,KAAK,CAAC4B,4BAA4B,GAAGjC,aAAK,CAACC,OAAO,CAChD,IAAI,CAAChB,MAAM,CAACqE,mCAAmC,EAAE,CAClD;IACH;IAEA,OAAO,IAAI,CAACrE,MAAM,CAACyC,QAAQ,CAACF,MAAM,CAChC,OAAO,EACP;MAAE+B,GAAG,EAAE,CAAC;QAAElB;MAAM,CAAC,EAAE;QAAEjC,QAAQ,EAAEiC,KAAK;QAAEA,KAAK,EAAE;UAAEmB,OAAO,EAAE;QAAM;MAAE,CAAC;IAAE,CAAC,EACpEnD,KAAK,EACL,CAAC,CAAC,EACF,IAAI,CACL;EACH;EAEA,MAAMoD,sBAAsB,CAACpB,KAAK,EAAE;IAClC,IAAI,CAAC,IAAI,CAACvD,OAAO,EAAE;MACjB,MAAM,uDAAuD;MAC7D;IACF;;IACA,IAAIY,IAAI;IACR,IACE,IAAI,CAACT,MAAM,CAAC6C,cAAc,IAC1B,IAAI,CAAC7C,MAAM,CAAC6C,cAAc,CAAC4B,sBAAsB,IACjD,IAAI,CAACzE,MAAM,CAAC6C,cAAc,CAACC,0BAA0B,EACrD;MACA,MAAMb,OAAO,GAAG,MAAM,IAAI,CAACjC,MAAM,CAACyC,QAAQ,CAACC,IAAI,CAC7C,OAAO,EACP;QACE4B,GAAG,EAAE,CACH;UAAElB,KAAK;UAAET,iBAAiB,EAAE;YAAE4B,OAAO,EAAE;UAAK;QAAE,CAAC,EAC/C;UAAEpD,QAAQ,EAAEiC,KAAK;UAAEA,KAAK,EAAE;YAAEmB,OAAO,EAAE;UAAM,CAAC;UAAE5B,iBAAiB,EAAE;YAAE4B,OAAO,EAAE;UAAK;QAAE,CAAC;MAExF,CAAC,EACD;QAAE3B,KAAK,EAAE;MAAE,CAAC,EACZnD,IAAI,CAACmC,WAAW,CAAC,IAAI,CAAC5B,MAAM,CAAC,CAC9B;MACD,IAAIiC,OAAO,CAACC,MAAM,IAAI,CAAC,EAAE;QACvB,IAAIa,WAAW,GAAGd,OAAO,CAAC,CAAC,CAAC,CAACe,4BAA4B;QACzD,IAAID,WAAW,IAAIA,WAAW,CAACE,MAAM,IAAI,MAAM,EAAE;UAC/CF,WAAW,GAAG,IAAIrB,IAAI,CAACqB,WAAW,CAACG,GAAG,CAAC;QACzC;QACA,IAAIH,WAAW,GAAG,IAAIrB,IAAI,EAAE,EAAE;UAC5BjB,IAAI,GAAGwB,OAAO,CAAC,CAAC,CAAC;QACnB;MACF;IACF;IACA,IAAI,CAACxB,IAAI,IAAI,CAACA,IAAI,CAACkC,iBAAiB,EAAE;MACpClC,IAAI,GAAG,MAAM,IAAI,CAAC2D,qBAAqB,CAAChB,KAAK,CAAC;IAChD;IACA,MAAMhC,KAAK,GAAGoC,kBAAkB,CAAC/C,IAAI,CAACkC,iBAAiB,CAAC;IACxD,MAAMxB,QAAQ,GAAGqC,kBAAkB,CAAC/C,IAAI,CAACU,QAAQ,CAAC;IAElD,MAAMsC,IAAI,GAAGC,cAAc,CAAC,IAAI,CAAC1D,MAAM,CAAC0E,uBAAuB,EAAEvD,QAAQ,EAAEC,KAAK,EAAE,IAAI,CAACpB,MAAM,CAAC;IAC9F,MAAMD,OAAO,GAAG;MACd6D,OAAO,EAAE,IAAI,CAAC5D,MAAM,CAAC4D,OAAO;MAC5BH,IAAI,EAAEA,IAAI;MACVhD,IAAI,EAAE,IAAAoD,iBAAO,EAAC,OAAO,EAAEpD,IAAI;IAC7B,CAAC;IAED,IAAI,IAAI,CAACZ,OAAO,CAAC2E,sBAAsB,EAAE;MACvC,IAAI,CAAC3E,OAAO,CAAC2E,sBAAsB,CAACzE,OAAO,CAAC;IAC9C,CAAC,MAAM;MACL,IAAI,CAACF,OAAO,CAACiE,QAAQ,CAAC,IAAI,CAACa,yBAAyB,CAAC5E,OAAO,CAAC,CAAC;IAChE;IAEA,OAAOoC,OAAO,CAACC,OAAO,CAAC3B,IAAI,CAAC;EAC9B;EAEAmE,cAAc,CAACzD,QAAQ,EAAEC,KAAK,EAAEyD,QAAQ,EAAE;IACxC,OAAO,IAAI,CAACrC,uBAAuB,CAACrB,QAAQ,EAAEC,KAAK,CAAC,CACjDW,IAAI,CAACtB,IAAI,IAAIqE,kBAAkB,CAACrE,IAAI,EAAEoE,QAAQ,EAAE,IAAI,CAAC7E,MAAM,CAAC,CAAC,CAC7D+B,IAAI,CAACtB,IAAI,IAAI;MACZ,MAAMsE,oBAAoB,GAAG,IAAIC,uBAAc,CAACvE,IAAI,EAAE,IAAI,CAACT,MAAM,CAAC;MAClE,OAAO+E,oBAAoB,CAACE,aAAa,EAAE;IAC7C,CAAC,CAAC,CACDC,KAAK,CAACC,KAAK,IAAI;MACd,IAAIA,KAAK,IAAIA,KAAK,CAACC,OAAO,EAAE;QAC1B;QACA,OAAOjD,OAAO,CAACkD,MAAM,CAACF,KAAK,CAACC,OAAO,CAAC;MACtC,CAAC,MAAM;QACL,OAAOjD,OAAO,CAACkD,MAAM,CAACF,KAAK,CAAC;MAC9B;IACF,CAAC,CAAC;EACN;EAEApB,wBAAwB,CAAC;IAAEN,IAAI;IAAEhD,IAAI;IAAEmD;EAAQ,CAAC,EAAE;IAChD,MAAM0B,IAAI,GACR,SAAS,GACT,oDAAoD,GACpD7E,IAAI,CAACP,GAAG,CAAC,OAAO,CAAC,GACjB,QAAQ,GACR0D,OAAO,GACP,MAAM,GACN,EAAE,GACF,6BAA6B,GAC7BH,IAAI;IACN,MAAM8B,EAAE,GAAG9E,IAAI,CAACP,GAAG,CAAC,OAAO,CAAC;IAC5B,MAAMsF,OAAO,GAAG,gCAAgC,GAAG5B,OAAO;IAC1D,OAAO;MAAE0B,IAAI;MAAEC,EAAE;MAAEC;IAAQ,CAAC;EAC9B;EAEAb,yBAAyB,CAAC;IAAElB,IAAI;IAAEhD,IAAI;IAAEmD;EAAQ,CAAC,EAAE;IACjD,MAAM0B,IAAI,GACR,SAAS,GACT,2CAA2C,GAC3C1B,OAAO,IACNnD,IAAI,CAACP,GAAG,CAAC,UAAU,CAAC,GAAG,sBAAsB,GAAGO,IAAI,CAACP,GAAG,CAAC,UAAU,CAAC,GAAG,IAAI,GAAG,EAAE,CAAC,GAClF,OAAO,GACP,EAAE,GACF,2BAA2B,GAC3BuD,IAAI;IACN,MAAM8B,EAAE,GAAG9E,IAAI,CAACP,GAAG,CAAC,OAAO,CAAC,IAAIO,IAAI,CAACP,GAAG,CAAC,UAAU,CAAC;IACpD,MAAMsF,OAAO,GAAG,qBAAqB,GAAG5B,OAAO;IAC/C,OAAO;MAAE0B,IAAI;MAAEC,EAAE;MAAEC;IAAQ,CAAC;EAC9B;AACF;;AAEA;AAAA;AACA,SAASV,kBAAkB,CAACrE,IAAI,EAAEoE,QAAQ,EAAE7E,MAAM,EAAE;EAClD,OAAOsC,aAAI,CACRC,MAAM,CACLvC,MAAM,EACNP,IAAI,CAAC6D,MAAM,CAACtD,MAAM,CAAC,EACnB,OAAO,EACP;IAAEqC,QAAQ,EAAE5B,IAAI,CAAC4B;EAAS,CAAC,EAC3B;IACEwC,QAAQ,EAAEA;EACZ,CAAC,CACF,CACA9C,IAAI,CAAC,MAAMtB,IAAI,CAAC;AACrB;AAEA,SAASiD,cAAc,CAAC+B,WAAW,EAAEtE,QAAQ,EAAEC,KAAK,EAAEpB,MAAM,EAAE;EAC5D,MAAM0F,gBAAgB,GAAI,SAAQtE,KAAM,aAAYD,QAAS,EAAC;EAE9D,IAAInB,MAAM,CAAC2F,aAAa,EAAE;IACxB,MAAMC,sBAAsB,GAAGH,WAAW,CAACI,OAAO,CAAC7F,MAAM,CAAC8F,eAAe,EAAE,EAAE,CAAC;IAE9E,OAAQ,GAAE9F,MAAM,CAAC2F,aAAc,SAAQnC,kBAAkB,CACvDoC,sBAAsB,CACtB,IAAGF,gBAAiB,EAAC;EACzB,CAAC,MAAM;IACL,OAAQ,GAAED,WAAY,IAAGC,gBAAiB,EAAC;EAC7C;AACF;AAAC,eAEchG,cAAc;AAAA"}